150 lines
5.1 KiB
Python
150 lines
5.1 KiB
Python
# -*- encoding: utf-8 -*-
|
|
##############################################################################
|
|
#
|
|
# OpenERP, Open Source Management Solution
|
|
# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>). All Rights Reserved
|
|
# $Id$
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
##############################################################################
|
|
from osv import fields
|
|
import wizard
|
|
import pooler
|
|
import time
|
|
|
|
def _invoice_membership(self, cr, uid, data, context):
|
|
partner_ids = data['ids']
|
|
product_id = data['form']['product']
|
|
|
|
pool = pooler.get_pool(cr.dbname)
|
|
|
|
cr.execute('''
|
|
SELECT partner_id, id, type
|
|
FROM res_partner_address
|
|
WHERE partner_id IN (%s)
|
|
''' % ','.join([str(id) for id in partner_ids])
|
|
)
|
|
fetchal = cr.fetchall()
|
|
if not fetchal:
|
|
raise wizard.except_wizard('Error !', 'No Address defined for this partner')
|
|
partner_address_ids = {}
|
|
for x in range(len(fetchal)):
|
|
pid = fetchal[x][0]
|
|
id = fetchal[x][1]
|
|
type = fetchal[x][2]
|
|
|
|
if partner_address_ids.has_key(pid) and partner_address_ids[pid]['type'] == 'invoice':
|
|
continue
|
|
partner_address_ids[pid] = {'id': id, 'type': type}
|
|
|
|
|
|
invoice_list= []
|
|
invoice_obj = pool.get('account.invoice')
|
|
partner_obj = pool.get('res.partner')
|
|
product_obj = pool.get('product.product')
|
|
invoice_line_obj = pool.get(('account.invoice.line'))
|
|
invoice_tax_obj = pool.get(('account.invoice.tax'))
|
|
product = product_obj.read(cr, uid, product_id, ['uom_id'])
|
|
|
|
for partner_id in partner_ids:
|
|
account_id = partner_obj.read(cr, uid, partner_id, ['property_account_receivable'])['property_account_receivable'][0]
|
|
read_fpos = partner_obj.read(cr, uid, partner_id, ['property_account_position'])
|
|
fpos_id = read_fpos['property_account_position'] and read_fpos['property_account_position'][0]
|
|
line_value = {
|
|
'product_id' : product_id,
|
|
}
|
|
|
|
quantity = 1
|
|
|
|
line_dict = invoice_line_obj.product_id_change(cr, uid, {}, product_id, product['uom_id'][0], quantity, '', 'out_invoice', partner_id, fpos_id, context=context)
|
|
line_value.update(line_dict['value'])
|
|
if line_value['invoice_line_tax_id']:
|
|
tax_tab = [(6, 0, line_value['invoice_line_tax_id'])]
|
|
line_value['invoice_line_tax_id'] = tax_tab
|
|
invoice_line_id = invoice_line_obj.create(cr, uid, line_value)
|
|
invoice_id = invoice_obj.create(cr, uid, {
|
|
'partner_id' : partner_id,
|
|
'address_invoice_id': partner_address_ids[partner_id]['id'],
|
|
'account_id': account_id,
|
|
'invoice_line':[(6,0,[invoice_line_id])],
|
|
'fiscal_position': fpos_id or False
|
|
}
|
|
)
|
|
invoice_list.append(invoice_id)
|
|
if line_value['invoice_line_tax_id']:
|
|
invoice_obj.write(cr, uid, [invoice_id], {'tax_line':tax_tab})
|
|
tax_value = invoice_tax_obj.compute(cr, uid, invoice_id).values()[0]
|
|
invoice_tax_obj.create(cr, uid, tax_value)
|
|
|
|
|
|
value = {
|
|
'domain': [
|
|
('id', 'in', invoice_list),
|
|
],
|
|
'name': 'Membership invoice',
|
|
'view_type': 'form',
|
|
'view_mode': 'tree,form',
|
|
'res_model': 'account.invoice',
|
|
'type': 'ir.actions.act_window',
|
|
}
|
|
|
|
return value
|
|
|
|
wizard_arch= """<?xml version="1.0"?>
|
|
<form string="Choose invoice details">
|
|
<field
|
|
name="product"
|
|
domain="[('membership','=','True')]"
|
|
context="product='membership_product'"
|
|
/>
|
|
</form>"""
|
|
|
|
|
|
|
|
class wizard_invoice_membership(wizard.interface):
|
|
|
|
states = {
|
|
|
|
'init' : {
|
|
'actions' : [],
|
|
'result' : {
|
|
'type' : 'form',
|
|
'arch' : wizard_arch,
|
|
'fields' : {
|
|
'product': {
|
|
'string': 'Membership product',
|
|
'type': 'many2one',
|
|
'relation': 'product.product',
|
|
'required': True
|
|
},
|
|
},
|
|
'state' : [('end', 'Cancel'),('ok', 'Confirm') ]}
|
|
},
|
|
|
|
'ok' : {
|
|
'actions' : [],
|
|
'result' : {'type' : 'action',
|
|
'action': _invoice_membership,
|
|
'state' : 'end'
|
|
},
|
|
},
|
|
|
|
}
|
|
|
|
wizard_invoice_membership("wizard_invoice_membership")
|
|
|
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
|
|