168 lines
5.3 KiB
Python
168 lines
5.3 KiB
Python
# -*- coding: utf-8 -*-
|
|
##############################################################################
|
|
#
|
|
# OpenERP, Open Source Management Solution
|
|
# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero 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 Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
##############################################################################
|
|
|
|
import wizard
|
|
import pooler
|
|
from tools.translate import _
|
|
|
|
invoice_form = """<?xml version="1.0"?>
|
|
<form string="Create invoices">
|
|
<separator colspan="4" string="Create invoices" />
|
|
<field name="journal_id"/>
|
|
<newline/>
|
|
<field name="group"/>
|
|
<newline/>
|
|
<field name="type"/>
|
|
<newline/>
|
|
<field name="invoice_date" />
|
|
</form>
|
|
"""
|
|
|
|
invoice_fields = {
|
|
'journal_id': {
|
|
'string': 'Destination Journal',
|
|
'type': 'many2one',
|
|
'relation': 'account.journal',
|
|
'required': True
|
|
},
|
|
'group': {
|
|
'string': 'Group by partner',
|
|
'type': 'boolean'
|
|
},
|
|
'type': {
|
|
'string': 'Type',
|
|
'type': 'selection',
|
|
'selection': [],
|
|
'required': True
|
|
},
|
|
'invoice_date': {'string': 'Invoiced date', 'type':'date' }
|
|
}
|
|
|
|
|
|
def _get_type(obj, cr, uid, data, context):
|
|
picking_obj = pooler.get_pool(cr.dbname).get('stock.picking')
|
|
usage = 'customer'
|
|
pick = picking_obj.browse(cr, uid, data['id'], context)
|
|
if pick.invoice_state == 'invoiced':
|
|
raise wizard.except_wizard(_('UserError'), _('Invoice is already created.'))
|
|
if pick.invoice_state == 'none':
|
|
raise wizard.except_wizard(_('UserError'), _('Invoice cannot be created from Picking.'))
|
|
|
|
if pick.move_lines:
|
|
usage = pick.move_lines[0].location_id.usage
|
|
|
|
if pick.type =='out':
|
|
invoice_fields['type']['selection'] = [
|
|
('out_invoice', 'Customer Invoice'),
|
|
('in_refund', 'Supplier Refund'),
|
|
]
|
|
elif pick.type =='in':
|
|
invoice_fields['type']['selection'] = [
|
|
('in_invoice', 'Supplier Invoice'),
|
|
('out_refund', 'Customer Refund'),
|
|
]
|
|
else:
|
|
invoice_fields['type']['selection']=[
|
|
('out_invoice', 'Customer Invoice'),
|
|
('in_invoice', 'Supplier Invoice'),
|
|
('out_refund', 'Customer Refund'),
|
|
('in_refund', 'Supplier Refund'),
|
|
]
|
|
|
|
if pick.type == 'out' and usage == 'supplier':
|
|
type = 'in_refund'
|
|
elif pick.type == 'out' and usage == 'customer':
|
|
type = 'out_invoice'
|
|
elif pick.type == 'in' and usage == 'supplier':
|
|
type = 'in_invoice'
|
|
elif pick.type == 'in' and usage == 'customer':
|
|
type = 'out_refund'
|
|
else:
|
|
type = 'out_invoice'
|
|
return {'type': type}
|
|
|
|
|
|
def _create_invoice(obj, cr, uid, data, context):
|
|
if data['form'].get('new_picking', False):
|
|
data['id'] = data['form']['new_picking']
|
|
data['ids'] = [data['form']['new_picking']]
|
|
pool = pooler.get_pool(cr.dbname)
|
|
picking_obj = pooler.get_pool(cr.dbname).get('stock.picking')
|
|
mod_obj = pool.get('ir.model.data')
|
|
act_obj = pool.get('ir.actions.act_window')
|
|
|
|
type = data['form']['type']
|
|
|
|
context['date_inv'] = data['form']['invoice_date']
|
|
res = picking_obj.action_invoice_create(cr, uid, data['ids'],
|
|
journal_id = data['form']['journal_id'], group=data['form']['group'],
|
|
type=type, context= context)
|
|
|
|
invoice_ids = res.values()
|
|
if not invoice_ids:
|
|
raise wizard.except_wizard(_('Error'), _('Invoice is not created'))
|
|
|
|
if type == 'out_invoice':
|
|
xml_id = 'action_invoice_tree5'
|
|
elif type == 'in_invoice':
|
|
xml_id = 'action_invoice_tree8'
|
|
elif type == 'out_refund':
|
|
xml_id = 'action_invoice_tree10'
|
|
else:
|
|
xml_id = 'action_invoice_tree12'
|
|
|
|
result = mod_obj._get_id(cr, uid, 'account', xml_id)
|
|
id = mod_obj.read(cr, uid, result, ['res_id'])
|
|
result = act_obj.read(cr, uid, id['res_id'])
|
|
result['res_id'] = invoice_ids
|
|
return result
|
|
|
|
|
|
class make_invoice_onshipping(wizard.interface):
|
|
states = {
|
|
'init': {
|
|
'actions': [_get_type],
|
|
'result': {
|
|
'type': 'form',
|
|
'arch': invoice_form,
|
|
'fields': invoice_fields,
|
|
'state': [
|
|
('end', 'Cancel'),
|
|
('create_invoice', 'Create invoice')
|
|
]
|
|
}
|
|
},
|
|
'create_invoice': {
|
|
'actions': [],
|
|
'result': {
|
|
'type': 'action',
|
|
'action': _create_invoice,
|
|
'state': 'end'
|
|
}
|
|
},
|
|
}
|
|
|
|
make_invoice_onshipping("stock.invoice_onshipping")
|
|
|
|
|
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
|
|