【发布时间】: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