【问题标题】:Creating more than one sequence on object - Odoo v8在对象上创建多个序列 - Odoo v8
【发布时间】:2017-09-17 04:50:25
【问题描述】:

我想根据Selection 字段为模型创建不同的序列。

现在我只有一个这样的序列:

@api.model
def create(self, vals):
    if vals.get('name', 'New') == 'New':
        vals['name'] = self.env['ir.sequence'].next_by_code('mrp.worksheet.contract') or '/'
    return super(mrp_worksheet_contract, self).create(vals)

name = fields.Char('Reference', required=True, index=True, copy=False, readonly='True', default='New')

_defaults = {
    'name': lambda self, cr, uid, context: self.pool.get('ir.sequence').next_by_code(cr, uid, 'mrp.worksheet.contract') or '',
}

但是如果我想基于这样的字段创建多个序列会发生什么:

type_prod = fields.Selection([
        ('budgeted','Budgeted'),
        ('nonbudgeted','Non Budgeted'),
        ('direct','Direct Order'),
    ], string='Type of Order', index=True,  
    track_visibility='onchange', copy=False,
    help=" ")

我的 xml 中声明了序列:

<openerp>
<data noupdate="1">
    <!-- Sequences for contracts --> 
    <record id="seq_type_contract_code" model="ir.sequence.type">
        <field name="name">contract sequence</field>
        <field name="code">mrp.worksheet.contract</field>
    </record>
    <record id="seq_contract_code" model="ir.sequence">
        <field name="name">contract sequence</field>
        <field name="code">mrp.worksheet.contract</field>
        <field name="prefix">10G-</field>
        <field name="padding">5</field>
        <field name="company_id" eval="False"/>
    </record>
</data>
</openerp>

我想我的 xml 中会有多个序列,但我找不到任何关于如何使用多个依赖于 Selection 字段的示例。

有什么想法吗?

编辑

我有这个模型,它有一个序列name 字段,我想要的是,取决于您在此字段上选择的选项

type_prod = fields.Selection([
    ('budgeted','Budgeted'),
    ('nonbudgeted','Non Budgeted'),
    ('direct','Direct Order'),
], string='Type of Order', index=True,  
track_visibility='onchange', copy=False,
help=" ")

要创建相同的记录但顺序不同,例如,如果用户选择budgeted,那么它将是BO000,如果选择nonbudgeted,则创建相同的记录但顺序不同,它'将是NBO000,如果是direct,则为DO000

【问题讨论】:

  • 您的意思是,取决于选择,当用户选择一个值时,您会从特定序列中选择值?!!你能解释一下吗
  • 嗨,谢谢,编辑了我的问题,请检查一下,再次感谢。

标签: python openerp odoo-8 qweb


【解决方案1】:

保存记录时,只需检查字段的值,然后从序列中选择值

        If vals.get('name', 'New') == 'New':
               if vals.get('typo_prod') == 'budgeted':
                      vals['name'] = self.env['ir.sequence'].next_by_code('mrp.worksheet.contract') or '/'
               elif vals.get('typo_prod') == 'nonbudgeted':
                      vals['name'] = self.env['ir.sequence'].next_by_code('mrp.second_sequence') or '/'

我认为这可以完成工作,希望您能理解

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多