[MERGE]
authorUjjvala Collins (OpenERP) <uco@tinyerp.com>
Tue, 24 May 2011 13:35:24 +0000 (19:05 +0530)
committerUjjvala Collins (OpenERP) <uco@tinyerp.com>
Tue, 24 May 2011 13:35:24 +0000 (19:05 +0530)
bzr revid: uco@tinyerp.com-20110524133524-fhtgzbknh1wa9ypi

addons/account_asset/account_asset.py
addons/account_asset/account_asset_invoice.py
addons/account_asset/account_asset_invoice_view.xml
addons/account_asset/account_asset_view.xml

index 0bf61c1..b09644f 100644 (file)
@@ -37,6 +37,7 @@ class account_asset_category(osv.osv):
         'account_expense_depreciation_id': fields.many2one('account.account', 'Depr. Expense Account', required=True),
         'journal_id': fields.many2one('account.journal', 'Journal', required=True),
         'company_id': fields.many2one('res.company', 'Company', required=True),
+        'asset_normal': fields.boolean('Skip Draft State', help="Check this if you want to skip draft state for asset when it is created by invoice."),
     }
 
     _defaults = {
index 1bc9fbc..800e149 100755 (executable)
@@ -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.asset_normal:
+                asset_obj.validate(cr, uid, [asset_id], context=context)
         return res
 account_invoice_line()
 
index 394d173..f694ce4 100755 (executable)
@@ -13,7 +13,7 @@
         <field name="type">form</field>
         <field name="arch" type="xml">
             <field name="invoice_line_tax_id" position="before">
-                <field name="asset_id" context="name=name"/>
+                <field name="asset_category_id" context="name=name"/>
             </field>
         </field>
     </record>
index e25a8a0..cc4d035 100644 (file)
@@ -15,6 +15,7 @@
                 <field name="account_asset_id"/>
                 <field name="account_depreciation_id"/>
                 <field name="account_expense_depreciation_id"/>
+                <field name="asset_normal"/>
                <group col="4" colspan="4" groups="analytic.group_analytic_accounting">
                    <separator string="Analytic information" colspan="4" />
                    <newline/>