Added account_anglo_saxon module from extra addons
[odoo/odoo.git] / addons / account_anglo_saxon / invoice.py
1 ##############################################################################
2 #    
3 #    OpenERP, Open Source Management Solution
4 #    Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
5 #
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.
10 #
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.
15 #
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/>.     
18 #
19 ##############################################################################
20
21 from osv import fields, osv
22
23 class account_invoice_line(osv.osv):
24     _inherit = "account.invoice.line"
25     
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:
31                 if i_line.product_id:
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
34                         if not dacc:
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
36                     else:
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
38                         if not dacc:
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
40                             
41                     cacc = i_line.product_id.product_tmpl_id.property_account_expense and i_line.product_id.product_tmpl_id.property_account_expense.id
42                     if not cacc:
43                         cacc = i_line.product_id.categ_id.property_account_expense_categ and i_line.product_id.categ_id.property_account_expense_categ.id
44                     if dacc and cacc:
45                         res.append({
46                             'type':'src',
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,
51                             'account_id':dacc,
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,
56                             })
57                         
58                         res.append({
59                             'type':'src',
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,
64                             'account_id':cacc,
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,
69                             })
70         elif inv.type in ('in_invoice','in_refund'):
71             for i_line in inv.invoice_line:
72                 if i_line.product_id:
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
75                         if not acc:
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
77                         a = None
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
80                             if not oa:
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
82                         else:
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
84                             if not oa:
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
86                         if oa:
87                             fpos = i_line.invoice_id.fiscal_position or False
88                             a = self.pool.get('account.fiscal.position').map_account(cr, uid, fpos, oa)
89                         diff_res = []
90                         for line in res:
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']})
97                                     diff_res.append({
98                                         'type':'src',
99                                         'name': i_line.name[:64],
100                                         'price_unit':price_diff,
101                                         'quantity':line['quantity'],
102                                         'price': price_diff * line['quantity'],
103                                         'account_id':acc,
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',[]),
108                                         })
109                         res += diff_res
110         return res   
111     
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):
113         if not product:
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)
115         else:
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)
117
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
122                 if not oa:
123                     oa = product_obj.categ_id.property_stock_account_input_categ and product_obj.categ_id.property_stock_account_input_categ.id
124             else:
125                 oa = product_obj.product_tmpl_id.property_stock_account_output and product_obj.product_tmpl_id.property_stock_account_output.id
126                 if not oa:
127                     oa = product_obj.categ_id.property_stock_account_output_categ and product_obj.categ_id.property_stock_account_output_categ.id
128             if oa:
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})            
132         return res
133          
134 account_invoice_line()
135
136 class account_invoice(osv.osv):
137     _inherit = "account.invoice"
138
139     def _refund_cleanup_lines(self, cr, uid, lines):
140         for line in 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
147                     if not oa:
148                         oa = product_obj.categ_id.property_stock_account_output_categ and product_obj.categ_id.property_stock_account_output_categ.id
149                     if oa:
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)
155         return res
156     
157 account_invoice()
158 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: