模块Openerp 6.1 - 视图

时间:2018-03-31 20:20:26

标签: python xml odoo openerp-6

我正在用Python做一些功课。我需要为OpenErp 6.1创建一个新模块,当我尝试安装升级时,我会看到弹出的下一条消息:

  

OpenERP警告
  ValidateError
  验证字段拱时出错:视图架构的XML无效!

我附上了我开发的代码。
任何人都可以帮助我。

__初始化__。PY

import library

__的OpenERP __。PY

{
    'name' : "Library",
    'version' : "1.0",
    'depends' : [
        "base"
    ],
    'author' : "JuanRa",
    'category': 'Tools',
    'description': u"""  
Library - Cine, Música y Libros Este módulo se va a encargar de gestionar cine, música y libros. Además se puede marcar como leídas y configurar varias opciones.
    """,
    'website': '',
    'data': [    
        'library_view.xml',    
    ],
    'installable': True,   
}

library.py

import pdb 
import sys 
import time
import logging

from datetime import date, datetime, timedelta 
from openerp.osv import osv, fields 
from openerp.tools.translate import 


sys.setdefaultencoding('iso-8859-1')

class library(osv.Model):
    _name = 'library'
    _description = u'library class'

    def _get_global_score(self, cr, uid, ids, field_name, field_value, context = None):
        res = {}
        pdb.set_trace()
        for id in ids:
            res[id] = 0.0

        return res

    _columns = {
        'name': fields.char(_(u'Nombre del Libro'), size = 128, required = True),
        'year': fields.integer(_(u'Año de inicio')),
        'no_more_seassons': fields.boolean(_(u'No hay mas temporadas')),
        'is_serie': fields.boolean(_(u'¿Es serie?')),
        'global_score': fields.function(_get_global_score, type='float', digits=(12,2), string=_(u'Total puntuación')),
        'full_view': fields.boolean(_(u'Visualizado por completo')),
        #'line_ids': fields.one2many('library.lines', 'library_id', string=_(u'Líbros/Capítulos')),
    }

    _default = {
        'year': lambda self, cr, uid, ids: datetime.now().year,
    }

    def mark_as_seen(self, cr, uid, ids, context = None):
        osv.logging.log(100, "[JuanRa] mark_as_seen:library:library (%s)" % (uid))

        #Modelos
        mlibrary = self.pool.get('library')

        #Ejecucion
        mlibrary.write(cr, uid, ids, {'full_view': True}, context)

library_view.xml

<openerp>
    <data>

        <record id='view_library_form' model='ir.ui.view'>
            <field name='name'>view.library.form</field>
            <field name='model'>library</field>
            <field name='arch' type='xml'>
                <form string='Library' version='7.0'>
                    <sheet>
                        <group col='4'>
                            <group>
                                <field name='name' />
                                <field name='year' />
                                <field name='global_score' />
                            </group>
                            <group>
                                <field name='is_serie' />
                                <field name='no_more_seasons' attrs="{'invisible':[('is_seire','=',False)]}" />
                                <field name='full_view' />
                            </group>
                        </group>
                    </sheet>
                </form>
            </field>
        </record>

        <record id='view_library_tree' model='ir.ui.view'>
            <field name='name'>view.library.tree</field>
            <field name="model">library</field>
            <field name="arch" type='xml'>
                <tree string='Library' version='7.0' colors='green:full_view==True'>
                    <field name='name' />
                    <field name='year' />
                    <field name='global_score' />
                    <field name='full_view' />
                </tree>
            </field>                                            
        </record>

        <record id='view_library_search' model='ir.ui.view'>
            <field name="name">view.library.search</field>
            <field name="model">library</field>
            <field name="arch" type='xml'>
                <search string='Busqueda library' version='7.0'>
                    <field name='name' />
                    <field name='year' />

                    <filter string='Vistas' name='seen' domain="[('full_view', '=', True)]"/>
                    <filter string='No Vistas' name='unseen' domain="[('full_view', '=', False)]"/>
                    <filter string='No Vistas o que sean del 2014' name='unseen_year' domain="['|',('full_view', '=', False),('year','=','2014')]"/>

                    <group expand='1' string="Group by">
                        <filter name='group_by_year' string='Año' context="{('group_by':'year')}" />                    
                    </group>
                </search>
            </field>                                            
        </record>

        <record id='action_library_series_libros' model='ir.actions.act_window'>
            <field name="name">Series y Libros</field>
            <field name="res_model">library</field>
            <field name="view_mode">tree, form</field>
            <field name="view_type">form</field>
            <field name="search_view_id" ref="view_library_search"/>                                
        </record>

        <menuitem name="Library" id="menu_library_main" sequence="25" />
            <menuitem name="Library" id="menu_library_sub" sequence="1" parent="menu_library_main"/>
                <menuitem id="menu_library_series_libros" sequence="1" 
                          parent="menu_library_sub" action="action_library_series_libros" />

        <!-- Ejemplo de accion de servidor -->                
        <record id='action_server_mark_as_seen' model='ir.actions.server'>
            <field name="name">Marcar como vistas</field>
            <field name="condition">True</field>
            <field name="type">ir.actions.server</field>
            <field name="model_id" ref="model_library" />
            <field name="state">code</field>    
            <field name="code">self.mark_as_seen(cr, uid, context.get('active_ids', []), context=context)</field>
        </record>

        <!-- Ejemplo de llamada accion de servidor -->                
        <record id='ir.values' model='action_library_mark_as_seen'>
            <field name="name">Marcar como vistas</field>
            <field name="action_id" ref='action_server_mark_as_seen' />
            <field name="value" eval="'ir.actions.server,' + str(ref('action_server_mark_as_seen'))" />
            <field name="key">action</field>
            <field name="model_id" ref="model_library" />
            <field name="model">library</field>  
            <field name="key2">client_action_multi</field>                              
        </record>

    </data>
</openerp>

1 个答案:

答案 0 :(得分:0)

请从表单视图中删除import { Component } from '@angular/core'; @Component({ selector: 'my-app', template: ` <div *ngFor="let item of items; let i=index"> <div>{{item | json}}</div> <div> <kendo-numerictextbox [(ngModel)]="item.units"></kendo-numerictextbox> <kendo-numerictextbox [(ngModel)]="item.price"></kendo-numerictextbox> <kendo-numerictextbox [readonly]="true" [value]="getTotal(item)"></kendo-numerictextbox> </div> </div> ` }) export class AppComponent { public items = [{units:10,price:20},{units:20,price:23}]; public getTotal(item) { return item.units*item.price; } }