Nicolas Bessi - Camptocamp has proposed merging lp:~camptocamp/banking-addons/bank-statement-reconcile-70-voucher-killer into lp:banking-addons/bank-statement-reconcile-70.
Requested reviews: Banking Addons Team (banking-addons-team) For more details, see: https://code.launchpad.net/~camptocamp/banking-addons/bank-statement-reconcile-70-voucher-killer/+merge/148434 Adds two add-ons that prevent voucher to interfer with the statement ext related add-ons flow. -- https://code.launchpad.net/~camptocamp/banking-addons/bank-statement-reconcile-70-voucher-killer/+merge/148434 Your team Banking Addons Team is requested to review the proposed merge of lp:~camptocamp/banking-addons/bank-statement-reconcile-70-voucher-killer into lp:banking-addons/bank-statement-reconcile-70.
=== added directory 'invoicing_voucher_killer' === added file 'invoicing_voucher_killer/__init__.py' --- invoicing_voucher_killer/__init__.py 1970-01-01 00:00:00 +0000 +++ invoicing_voucher_killer/__init__.py 2013-02-14 12:20:31 +0000 @@ -0,0 +1,20 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Copyright (c) 2013 Camptocamp SA (http://www.camptocamp.com) +# @author Nicolas Bessi +# +# 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/>. +# +############################################################################## === added file 'invoicing_voucher_killer/__openerp__.py' --- invoicing_voucher_killer/__openerp__.py 1970-01-01 00:00:00 +0000 +++ invoicing_voucher_killer/__openerp__.py 2013-02-14 12:20:31 +0000 @@ -0,0 +1,39 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Copyright (c) 2013 Camptocamp SA (http://www.camptocamp.com) +# @author Nicolas Bessi +# +# 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/>. +# +############################################################################## + +{'name': 'Invoicing voucher killer', + 'version': '1.0.0', + 'category': 'other', + 'description': """ +Prevent the usage of voucher from invoices +########################################## +This add-on will disable "Register Payment" button +""", + 'author': 'Camptocamp', + 'website': 'http://www.camptocamp.com', + 'depends': ['account_voucher'], + 'data': ['invoice_data.xml', + 'invoice_view.xml'], + 'demo_xml': [], + 'test': [], + 'installable': True, + 'active': False, + } === added file 'invoicing_voucher_killer/invoice_data.xml' --- invoicing_voucher_killer/invoice_data.xml 1970-01-01 00:00:00 +0000 +++ invoicing_voucher_killer/invoice_data.xml 2013-02-14 12:20:31 +0000 @@ -0,0 +1,7 @@ +<openerp> + <data> + <record id="invoice_voucher_user" model="res.groups"> + <field name="name">Use voucher in Invoices</field> + </record> + </data> +</openerp> === added file 'invoicing_voucher_killer/invoice_view.xml' --- invoicing_voucher_killer/invoice_view.xml 1970-01-01 00:00:00 +0000 +++ invoicing_voucher_killer/invoice_view.xml 2013-02-14 12:20:31 +0000 @@ -0,0 +1,48 @@ +<openerp> + <data> + <record id="invoice_voucher_group" model="ir.ui.view"> + <field name="name">Hide voucher in invoice</field> + <field name="model">account.invoice</field> + <field name="inherit_id" ref="account_voucher.view_invoice_customer" /> + <field name="type">form</field> + <field name="arch" type="xml"> + <xpath expr="//button[@name='invoice_pay_customer'][last()]" + position="replace"> + <button name="invoice_pay_customer" + type="object" + string="Register Payment" + attrs="{'invisible': ['|', ('state','!=','open'), ('sent','=',True)]}" + groups="invoicing_voucher_killer.invoice_voucher_user"/> + </xpath> + <xpath expr="//button[@name='invoice_pay_customer'][1]" + position="replace"> + <button name="invoice_pay_customer" + type="object" + string="Register Payment" + attrs="{'invisible': ['|', ('state','!=','open'), ('sent','=',False)]}" + class="oe_highlight" + groups="invoicing_voucher_killer.invoice_voucher_user"/> + </xpath> + </field> + </record> + + <record id="invoice_voucher_group_supp_inv" model="ir.ui.view"> + <field name="name">Hide voucher in supplier invoice</field> + <field name="model">account.invoice</field> + <field name="inherit_id" ref="account_voucher.view_invoice_supplier" /> + <field name="type">form</field> + <field name="arch" type="xml"> + <xpath expr="//button[@name='invoice_pay_customer'][last()]" + position="replace"> + <button name="invoice_pay_customer" + type="object" + string="Pay" + states="open" + class="oe_highlight" + groups="invoicing_voucher_killer.invoice_voucher_user"/> + </xpath> + </field> + </record> + + </data> +</openerp> === added directory 'statement_voucher_killer' === added file 'statement_voucher_killer/__init__.py' --- statement_voucher_killer/__init__.py 1970-01-01 00:00:00 +0000 +++ statement_voucher_killer/__init__.py 2013-02-14 12:20:31 +0000 @@ -0,0 +1,21 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Copyright (c) 2013 Camptocamp SA (http://www.camptocamp.com) +# @author Nicolas Bessi +# +# 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/>. +# +############################################################################## +from . import voucher === added file 'statement_voucher_killer/__openerp__.py' --- statement_voucher_killer/__openerp__.py 1970-01-01 00:00:00 +0000 +++ statement_voucher_killer/__openerp__.py 2013-02-14 12:20:31 +0000 @@ -0,0 +1,40 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Copyright (c) 2013 Camptocamp SA (http://www.camptocamp.com) +# @author Nicolas Bessi +# +# 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/>. +# +############################################################################## + +{'name': 'voucher killer', + 'version': '1.0.0', + 'category': 'other', + 'description': """ +Prevent voucher creation when importing lines into statement. +############################################################# + +When importing invoice or payment into a bank statement or a payment order, normaly a +draf voucher is created on the line. This module will disable this voucher creation""", + 'author': 'Camptocamp', + 'website': 'http://www.camptocamp.com', + 'depends': ['account_voucher', 'account_payment'], + 'init_xml': [], + 'update_xml': [], + 'demo_xml': [], + 'test': [], + 'installable': True, + 'active': False, + } === added file 'statement_voucher_killer/voucher.py' --- statement_voucher_killer/voucher.py 1970-01-01 00:00:00 +0000 +++ statement_voucher_killer/voucher.py 2013-02-14 12:20:31 +0000 @@ -0,0 +1,128 @@ +# -*- coding: utf-8 -*- +############################################################################## +# +# Copyright (c) 2013 Camptocamp SA (http://www.camptocamp.com) +# @author Nicolas Bessi +# +# 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/>. +# +############################################################################## +from openerp.osv import orm + +import time + + +class AccountStatementFromInvoiceLines(orm.TransientModel): + + _inherit = "account.statement.from.invoice.lines" + + def populate_statement(self, cr, uid, ids, context=None): + """Taken from account voucher as no hook is available. No function + no refactoring, just trimming the part that generates voucher""" + if context is None: + context = {} + statement_id = context.get('statement_id', False) + if not statement_id: + return {'type': 'ir.actions.act_window_close'} + data = self.read(cr, uid, ids, context=context)[0] + line_ids = data['line_ids'] + if not line_ids: + return {'type': 'ir.actions.act_window_close'} + + line_obj = self.pool.get('account.move.line') + statement_obj = self.pool.get('account.bank.statement') + statement_line_obj = self.pool.get('account.bank.statement.line') + currency_obj = self.pool.get('res.currency') + line_date = time.strftime('%Y-%m-%d') + statement = statement_obj.browse(cr, uid, statement_id, context=context) + # for each selected move lines + for line in line_obj.browse(cr, uid, line_ids, context=context): + ctx = context.copy() + # take the date for computation of currency => use payment date + ctx['date'] = line_date + amount = 0.0 + + if line.debit > 0: + amount = line.debit + elif line.credit > 0: + amount = -line.credit + + if line.amount_currency: + amount = currency_obj.compute(cr, uid, line.currency_id.id, + statement.currency.id, line.amount_currency, context=ctx) + elif (line.invoice and line.invoice.currency_id.id <> statement.currency.id): + amount = currency_obj.compute(cr, uid, line.invoice.currency_id.id, + statement.currency.id, amount, context=ctx) + + context.update({'move_line_ids': [line.id], + 'invoice_id': line.invoice.id}) + s_type = 'general' + if line.journal_id.type in ('sale', 'sale_refund'): + s_type = 'customer' + elif line.journal_id.type in ('purchase', 'purhcase_refund'): + s_type = 'supplier' + statement_line_obj.create(cr, uid, { + 'name': line.name or '?', + 'amount': amount, + 'type': s_type, + 'partner_id': line.partner_id.id, + 'account_id': line.account_id.id, + 'statement_id': statement_id, + 'ref': line.ref, + 'voucher_id': False, + 'date': time.strftime('%Y-%m-%d'), + }, context=context) + return {'type': 'ir.actions.act_window_close'} + + +class AccountPaymentPopulateStatement(orm.TransientModel): + _inherit = "account.payment.populate.statement" + + def populate_statement(self, cr, uid, ids, context=None): + """Taken from payment addon as no hook is vailable. No function + no refactoring, just trimming the part that generates voucher""" + line_obj = self.pool.get('payment.line') + statement_obj = self.pool.get('account.bank.statement') + statement_line_obj = self.pool.get('account.bank.statement.line') + currency_obj = self.pool.get('res.currency') + + if context is None: + context = {} + data = self.read(cr, uid, ids, [], context=context)[0] + line_ids = data['lines'] + if not line_ids: + return {'type': 'ir.actions.act_window_close'} + + statement = statement_obj.browse(cr, uid, context['active_id'], context=context) + + for line in line_obj.browse(cr, uid, line_ids, context=context): + ctx = context.copy() + ctx['date'] = line.ml_maturity_date # was value_date earlier,but this field exists no more now + amount = currency_obj.compute(cr, uid, line.currency.id, + statement.currency.id, line.amount_currency, context=ctx) + if not line.move_line_id.id: + continue + context.update({'move_line_ids': [line.move_line_id.id]}) + st_line_id = statement_line_obj.create(cr, uid, { + 'name': line.order_id.reference or '?', + 'amount': - amount, + 'type': 'supplier', + 'partner_id': line.partner_id.id, + 'account_id': line.move_line_id.account_id.id, + 'statement_id': statement.id, + 'ref': line.communication, + }, context=context) + + line_obj.write(cr, uid, [line.id], {'bank_statement_line_id': st_line_id}) + return {'type': 'ir.actions.act_window_close'}
-- Mailing list: https://launchpad.net/~banking-addons-team Post to : [email protected] Unsubscribe : https://launchpad.net/~banking-addons-team More help : https://help.launchpad.net/ListHelp

