From: Quentin (OpenERP) Date: Tue, 24 May 2011 15:52:19 +0000 (+0200) Subject: [MERGE] asset category on invoice line to create asset + skip draft state X-Git-Tag: 6.1.0-rc1-addons~3206^2~51 X-Git-Url: http://git.inspyration.org/?a=commitdiff_plain;h=ff2a539bd47f518af4b6a1a2ec6d7efc86188e73;hp=e43cf1e316488ae5e0d3a6cc9a832f50c21922fe;p=odoo%2Fodoo.git [MERGE] asset category on invoice line to create asset + skip draft state bzr revid: qdp-launchpad@openerp.com-20110524155219-jziowms0j98tjvap --- diff --git a/addons/account_asset/account_asset.py b/addons/account_asset/account_asset.py index a801d48..f5ef40c 100644 --- a/addons/account_asset/account_asset.py +++ b/addons/account_asset/account_asset.py @@ -43,6 +43,7 @@ class account_asset_category(osv.osv): 'method_progress_factor': fields.float('Progressif Factor'), 'method_time': fields.selection([('delay','Delay'),('end','Ending Period')], 'Time Method', required=True), 'prorata':fields.boolean('Prorata Temporis', help='Indicates that the accounting entries for this asset have to be done from the purchase date instead of the first January'), + 'open_asset': fields.boolean('Skip Draft State', help="Check this if you want to automatically confirm the assets of this category when created by invoice."), } _defaults = { diff --git a/addons/account_asset/account_asset_invoice.py b/addons/account_asset/account_asset_invoice.py index 1bc9fbc..f130bdc 100755 --- a/addons/account_asset/account_asset_invoice.py +++ b/addons/account_asset/account_asset_invoice.py @@ -33,13 +33,20 @@ account_invoice() class account_invoice_line(osv.osv): _inherit = 'account.invoice.line' _columns = { - 'asset_id': fields.many2one('account.asset.asset', 'Asset'), + 'asset_category_id': fields.many2one('account.asset.category', 'Asset Category'), } def move_line_get_item(self, cr, uid, line, context={}): + asset_obj = self.pool.get('account.asset.asset') res = super(account_invoice_line, self).move_line_get_item(cr, uid, line, context) - res['asset_id'] = line.asset_id.id or False - if line.asset_id.id and (line.asset_id.state=='draft'): - self.pool.get('account.asset.asset').validate(cr, uid, [line.asset_id.id], context) + if line.asset_category_id: + vals = { + 'name': line.product_id and (line.name + ": " + line.product_id.name) or line.name, + 'category_id': line.asset_category_id.id, + 'purchase_value': line.price_subtotal + } + asset_id = asset_obj.create(cr, uid, vals, context=context) + if line.asset_category_id.open_asset: + asset_obj.validate(cr, uid, [asset_id], context=context) return res account_invoice_line() diff --git a/addons/account_asset/account_asset_invoice_view.xml b/addons/account_asset/account_asset_invoice_view.xml index 394d173..f694ce4 100755 --- a/addons/account_asset/account_asset_invoice_view.xml +++ b/addons/account_asset/account_asset_invoice_view.xml @@ -13,7 +13,7 @@ form - + diff --git a/addons/account_asset/account_asset_view.xml b/addons/account_asset/account_asset_view.xml index 2acdd64..39e2a7f 100644 --- a/addons/account_asset/account_asset_view.xml +++ b/addons/account_asset/account_asset_view.xml @@ -21,13 +21,12 @@ - - + + - - - + +