1 ##############################################################################
3 # OpenERP, Open Source Management Solution
4 # Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
6 # This program is free software: you can redistribute it and/or modify
7 # it under the terms of the GNU Affero General Public License as
8 # published by the Free Software Foundation, either version 3 of the
9 # License, or (at your option) any later version.
11 # This program is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU Affero General Public License for more details.
16 # You should have received a copy of the GNU Affero General Public License
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
19 ##############################################################################
21 from osv import fields, osv
23 class account_invoice_line(osv.osv):
24 _inherit = "account.invoice.line"
26 def move_line_get(self, cr, uid, invoice_id, context=None):
27 res = super(account_invoice_line,self).move_line_get(cr, uid, invoice_id, context)
28 inv = self.pool.get('account.invoice').browse(cr, uid, invoice_id)
29 if inv.type in ('out_invoice','out_refund'):
30 for i_line in inv.invoice_line:
32 if inv.type == 'out_invoice':
33 dacc = i_line.product_id.product_tmpl_id.property_stock_account_output and i_line.product_id.product_tmpl_id.property_stock_account_output.id
35 dacc = i_line.product_id.categ_id.property_stock_account_output_categ and i_line.product_id.categ_id.property_stock_account_output_categ.id
37 dacc = i_line.product_id.product_tmpl_id.property_stock_account_input and i_line.product_id.product_tmpl_id.property_stock_account_input.id
39 dacc = i_line.product_id.categ_id.property_stock_account_input_categ and i_line.product_id.categ_id.property_stock_account_input_categ.id
41 cacc = i_line.product_id.product_tmpl_id.property_account_expense and i_line.product_id.product_tmpl_id.property_account_expense.id
43 cacc = i_line.product_id.categ_id.property_account_expense_categ and i_line.product_id.categ_id.property_account_expense_categ.id
47 'name': i_line.name[:64],
48 'price_unit':i_line.product_id.product_tmpl_id.standard_price,
49 'quantity':i_line.quantity,
50 'price':i_line.product_id.product_tmpl_id.standard_price * i_line.quantity,
52 'product_id':i_line.product_id.id,
53 'uos_id':i_line.uos_id.id,
54 'account_analytic_id':i_line.account_analytic_id.id,
55 'taxes':i_line.invoice_line_tax_id,
60 'name': i_line.name[:64],
61 'price_unit':i_line.product_id.product_tmpl_id.standard_price,
62 'quantity':i_line.quantity,
63 'price': -1 * i_line.product_id.product_tmpl_id.standard_price * i_line.quantity,
65 'product_id':i_line.product_id.id,
66 'uos_id':i_line.uos_id.id,
67 'account_analytic_id':i_line.account_analytic_id.id,
68 'taxes':i_line.invoice_line_tax_id,
70 elif inv.type in ('in_invoice','in_refund'):
71 for i_line in inv.invoice_line:
73 if i_line.product_id.product_tmpl_id.type != 'service':
74 acc = i_line.product_id.product_tmpl_id.property_account_creditor_price_difference and i_line.product_id.product_tmpl_id.property_account_creditor_price_difference.id
76 acc = i_line.product_id.categ_id.property_account_creditor_price_difference_categ and i_line.product_id.categ_id.property_account_creditor_price_difference_categ.id
78 if inv.type == 'in_invoice':
79 oa = i_line.product_id.product_tmpl_id.property_stock_account_input and i_line.product_id.product_tmpl_id.property_stock_account_input.id
81 oa = i_line.product_id.categ_id.property_stock_account_input_categ and i_line.product_id.categ_id.property_stock_account_input_categ.id
83 oa = i_line.product_id.product_tmpl_id.property_stock_account_output and i_line.product_id.product_tmpl_id.property_stock_account_output.id
85 oa = i_line.product_id.categ_id.property_stock_account_output_categ and i_line.product_id.categ_id.property_stock_account_output_categ.id
87 fpos = i_line.invoice_id.fiscal_position or False
88 a = self.pool.get('account.fiscal.position').map_account(cr, uid, fpos, oa)
91 if a == line['account_id'] and i_line.product_id.id == line['product_id']:
92 uom = i_line.product_id.uos_id or i_line.product_id.uom_id
93 standard_price = self.pool.get('product.uom')._compute_price(cr, uid, uom.id, i_line.product_id.product_tmpl_id.standard_price, i_line.uos_id.id)
94 if standard_price != i_line.price_unit and line['price'] == i_line.price_unit and acc:
95 price_diff = i_line.price_unit - standard_price
96 line.update({'price':standard_price * line['quantity']})
99 'name': i_line.name[:64],
100 'price_unit':price_diff,
101 'quantity':line['quantity'],
102 'price': price_diff * line['quantity'],
104 'product_id':line['product_id'],
105 'uos_id':line['uos_id'],
106 'account_analytic_id':line['account_analytic_id'],
107 'taxes':line.get('taxes',[]),
112 def product_id_change(self, cr, uid, ids, product, uom, qty=0, name='', type='out_invoice', partner_id=False, fposition_id=False, price_unit=False, address_invoice_id=False, context=None):
114 return super(account_invoice_line, self).product_id_change(cr, uid, ids, product, uom, qty, name, type, partner_id, fposition_id, price_unit, address_invoice_id, context)
116 res = super(account_invoice_line, self).product_id_change(cr, uid, ids, product, uom, qty, name, type, partner_id, fposition_id, price_unit, address_invoice_id, context)
118 if type in ('in_invoice','in_refund'):
119 product_obj = self.pool.get('product.product').browse(cr, uid, product, context=context)
120 if type == 'in_invoice':
121 oa = product_obj.product_tmpl_id.property_stock_account_input and product_obj.product_tmpl_id.property_stock_account_input.id
123 oa = product_obj.categ_id.property_stock_account_input_categ and product_obj.categ_id.property_stock_account_input_categ.id
125 oa = product_obj.product_tmpl_id.property_stock_account_output and product_obj.product_tmpl_id.property_stock_account_output.id
127 oa = product_obj.categ_id.property_stock_account_output_categ and product_obj.categ_id.property_stock_account_output_categ.id
129 fpos = fposition_id and self.pool.get('account.fiscal.position').browse(cr, uid, fposition_id) or False
130 a = self.pool.get('account.fiscal.position').map_account(cr, uid, fpos, oa)
131 res['value'].update({'account_id':a})
134 account_invoice_line()
136 class account_invoice(osv.osv):
137 _inherit = "account.invoice"
139 def _refund_cleanup_lines(self, cr, uid, lines):
141 inv_id = line['invoice_id']
142 inv_obj = self.browse(cr,uid,inv_id[0])
143 if inv_obj.type == 'in_invoice':
144 if line.get('product_id',False):
145 product_obj = self.pool.get('product.product').browse(cr,uid,line['product_id'][0])
146 oa = product_obj.product_tmpl_id.property_stock_account_output and product_obj.product_tmpl_id.property_stock_account_output.id
148 oa = product_obj.categ_id.property_stock_account_output_categ and product_obj.categ_id.property_stock_account_output_categ.id
150 fpos = inv_obj.fiscal_position or False
151 a = self.pool.get('account.fiscal.position').map_account(cr, uid, fpos, oa)
152 account_data = self.pool.get('account.account').read(cr,uid,[a],['name'])[0]
153 line.update({'account_id': (account_data['id'],account_data['name'])})
154 res = super(account_invoice,self)._refund_cleanup_lines(cr, uid, lines)
158 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: