跳至內容
選單
此問題已被標幟
1 回覆
3233 瀏覽次數

I have a problem since a month of updating the function field 'result' that uses a different field function 'field2' (updated without problems) ?


_name = 'x'
'field1': fields.integer(readonly=True),
'field2': fields.function(count_x_id_in_y, type='integer',
          store={'y': (get_x_id_from_y, ['x_id'], 10)}),
'result': fields.function(add, type='integer',
          store={'x': (lambda self, cr, uid, ids, c={}: ids, ['field1','field2'], 10)}),


def add(self, cr, uid, ids, field_name, args, context=None):
    res = {}
    for record in self.browse(cr, uid, ids, context=context):
        res[record.id] = record.field1 + record.field2

    return res

頭像
捨棄
最佳答案

Check the following code from sale/sale.py


 'amount_untaxed': fields.function(_amount_all, digits_compute=dp.get_precision('Account'), string='Untaxed Amount',
            store={
                'sale.order': (lambda self, cr, uid, ids, c={}: ids, ['order_line'], 10),
                'sale.order.line': (_get_order, ['price_unit', 'tax_id', 'discount', 'product_uom_qty'], 10),
            },
            multi='sums', help="The amount without tax.", track_visibility='always'),
'amount_tax': fields.function(_amount_all, digits_compute=dp.get_precision('Account'), string='VAT', store={ 'sale.order': (lambda self, cr, uid, ids, c={}: ids, ['order_line'], 10), 'sale.order.line': (_get_order, ['price_unit', 'tax_id', 'discount', 'product_uom_qty'], 10), }, multi='sums', help="The tax amount."),
'amount_total': fields.function(_amount_all, digits_compute=dp.get_precision('Account'), string='Total', store={ 'sale.order': (lambda self, cr, uid, ids, c={}: ids, ['order_line'], 10), 'sale.order.line': (_get_order, ['price_unit', 'tax_id', 'discount', 'product_uom_qty'], 10), }, multi='sums', help="The total amount."),


The use of multi parameter will solve your problem. 

頭像
捨棄
相關帖文 回覆 瀏覽次數 活動
2
1月 23
26213
4
6月 21
39384
1
12月 20
2611
1
4月 18
7690
3
9月 15
9541