Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[16.0][MIG] account_move_so_import #623

Merged
merged 14 commits into from
Apr 2, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
81 changes: 81 additions & 0 deletions account_move_so_import/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
===================================
Journal Entry Sale Order completion
===================================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:b908437dbdf6d9e1284ff6d521333a844e99a805f1b28925f28c6d5398ac77df
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Faccount--reconcile-lightgray.png?logo=github
:target: https://github.com/OCA/account-reconcile/tree/16.0/account_move_so_import
:alt: OCA/account-reconcile
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/account-reconcile-16-0/account-reconcile-16-0-account_move_so_import
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
:target: https://runboat.odoo-community.org/builds?repo=OCA/account-reconcile&target_branch=16.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This module extends the functionality of account_move_base_import
to add support for completion rules based on Sale Orders. This was initially
part of the module account_statement_base_completion, but is now separate to
keep dependencies separate.

**Table of contents**

.. contents::
:local:

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/account-reconcile/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/account-reconcile/issues/new?body=module:%20account_move_so_import%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
~~~~~~~

* Camptocamp

Contributors
~~~~~~~~~~~~

* Joël Grand-Guillaume <[email protected]>
* Leonardo Pistone <[email protected]>
* Matthieu Dietrich <[email protected]>

Maintainers
~~~~~~~~~~~

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
:alt: Odoo Community Association
:target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

This module is part of the `OCA/account-reconcile <https://github.com/OCA/account-reconcile/tree/16.0/account_move_so_import>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
1 change: 1 addition & 0 deletions account_move_so_import/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
18 changes: 18 additions & 0 deletions account_move_so_import/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Copyright 2011-2019 Camptocamp SA
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html)
{
"name": "Journal Entry Sale Order completion",
"version": "16.0.1.0.0",
"author": "Camptocamp,Odoo Community Association (OCA)",
"maintainer": "Camptocamp",
"category": "Finance",
"complexity": "easy",
"depends": ["account_move_base_import", "sale"],
"website": "https://github.com/OCA/account-reconcile",
"data": [
"data/completion_rule_data.xml",
],
"installable": True,
"auto_install": False,
"license": "AGPL-3",
}
16 changes: 16 additions & 0 deletions account_move_so_import/data/completion_rule_data.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<?xml version="1.0" encoding="utf-8" ?>
<odoo noupdate="1">

<record id="bank_statement_completion_rule_1" model="account.move.completion.rule">
<field name="name">Match from line name (based on SO number)</field>
<field name="sequence">50</field>
<field name="function_to_call">get_from_name_and_so</field>
</record>

<record id="bank_statement_completion_rule_2" model="account.move.completion.rule">
<field name="name">Match from line name (based on SO payment reference)</field>
<field name="sequence">55</field>
<field name="function_to_call">get_from_name_and_so_payment_ref</field>
</record>

</odoo>
43 changes: 43 additions & 0 deletions account_move_so_import/i18n/account_move_so_import.pot
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * account_move_so_import
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: account_move_so_import
#: model:ir.model,name:account_move_so_import.model_account_move_completion_rule
msgid "Account move completion method"
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields.selection,name:account_move_so_import.selection__account_move_completion_rule__function_to_call__get_from_name_and_so
msgid "From line name (based on SO number)"
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields.selection,name:account_move_so_import.selection__account_move_completion_rule__function_to_call__get_from_name_and_so_payment_ref
msgid "From line name (based on SO payment ref)"
msgstr ""

#. module: account_move_so_import
#. odoo-python
#: code:addons/account_move_so_import/models/account_move.py:0
#, python-format
msgid ""
"Line named \"%s\" was matched by more than one partner while looking on SO "
"by ref."
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields,field_description:account_move_so_import.field_account_move_completion_rule__function_to_call
msgid "Method"
msgstr ""
49 changes: 49 additions & 0 deletions account_move_so_import/i18n/es.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
# Spanish translation for banking-addons
# Copyright (c) 2014 Rosetta Contributors and Canonical Ltd 2014
# This file is distributed under the same license as the banking-addons package.
# FIRST AUTHOR <EMAIL@ADDRESS>, 2014.
#
msgid ""
msgstr ""
"Project-Id-Version: banking-addons\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2014-01-21 12:04+0000\n"
"PO-Revision-Date: 2014-06-05 22:41+0000\n"
"Last-Translator: Pedro Manuel Baeza <[email protected]>\n"
"Language-Team: Spanish <[email protected]>\n"
"Language: es\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"X-Launchpad-Export-Date: 2014-06-06 06:36+0000\n"
"X-Generator: Launchpad (build 17031)\n"

#. module: account_move_so_import
#: model:ir.model,name:account_move_so_import.model_account_move_completion_rule
#, fuzzy
msgid "Account move completion method"
msgstr "account.statement.completion.rule"

#. module: account_move_so_import
#: model:ir.model.fields.selection,name:account_move_so_import.selection__account_move_completion_rule__function_to_call__get_from_name_and_so
msgid "From line name (based on SO number)"
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields.selection,name:account_move_so_import.selection__account_move_completion_rule__function_to_call__get_from_name_and_so_payment_ref
msgid "From line name (based on SO payment ref)"
msgstr ""

#. module: account_move_so_import
#. odoo-python
#: code:addons/account_move_so_import/models/account_move.py:0
#, python-format
msgid ""
"Line named \"%s\" was matched by more than one partner while looking on SO "
"by ref."
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields,field_description:account_move_so_import.field_account_move_completion_rule__function_to_call
msgid "Method"
msgstr ""
45 changes: 45 additions & 0 deletions account_move_so_import/i18n/hr.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * account_move_so_import
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 12.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: Automatically generated\n"
"Language-Team: none\n"
"Language: hr\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && "
"n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n"

#. module: account_move_so_import
#: model:ir.model,name:account_move_so_import.model_account_move_completion_rule
msgid "Account move completion method"
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields.selection,name:account_move_so_import.selection__account_move_completion_rule__function_to_call__get_from_name_and_so
msgid "From line name (based on SO number)"
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields.selection,name:account_move_so_import.selection__account_move_completion_rule__function_to_call__get_from_name_and_so_payment_ref
msgid "From line name (based on SO payment ref)"
msgstr ""

#. module: account_move_so_import
#. odoo-python
#: code:addons/account_move_so_import/models/account_move.py:0
#, python-format
msgid ""
"Line named \"%s\" was matched by more than one partner while looking on SO "
"by ref."
msgstr ""

#. module: account_move_so_import
#: model:ir.model.fields,field_description:account_move_so_import.field_account_move_completion_rule__function_to_call
msgid "Method"
msgstr ""
3 changes: 3 additions & 0 deletions account_move_so_import/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# © 2011-2016 Camptocamp SA
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html)
from . import account_move
74 changes: 74 additions & 0 deletions account_move_so_import/models/account_move.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
# Copyright 2011-2019 Camptocamp SA
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html)
from odoo import _, fields, models

from odoo.addons.account_move_base_import.models.account_move import ErrorTooManyPartner


class AccountMoveCompletionRule(models.Model):

_name = "account.move.completion.rule"
_inherit = "account.move.completion.rule"

function_to_call = fields.Selection(
selection_add=[
("get_from_name_and_so", "From line name (based on SO number)"),
(
"get_from_name_and_so_payment_ref",
"From line name (based on SO payment ref)",
),
]
)

# Should be private but data are initialized with no update XML
def get_from_name_and_so(self, line):
"""
Match the partner based on the SO number and the reference of the
statement line. Then, call the generic get_values_for_line method to
complete other values. If more than one partner matched, raise the
ErrorTooManyPartner error.

:param int/long st_line: read of the concerned
account.bank.statement.line

:return:
A dict of value that can be passed directly to the write method of
the statement line or {}
{'partner_id': value,
'account_id': value,

...}
"""
return self._get_from_name_and_so_generic(line, "name")

# Should be private but data are initialized with no update XML
def get_from_name_and_so_payment_ref(self, line):
"""
:param int/long st_line: read of the concerned
account.bank.statement.line

:return:
A dict of value that can be passed directly to the write method of
the statement line or {}
{'partner_id': value,
'account_id': value,

...}
"""
return self._get_from_name_and_so_generic(line, "reference")

def _get_from_name_and_so_generic(self, line, search_by):
res = {}
so_obj = self.env["sale.order"]
orders = so_obj.search([(search_by, "=", line.name)])
if len(orders) > 1:
raise ErrorTooManyPartner(

Check warning on line 65 in account_move_so_import/models/account_move.py

View check run for this annotation

Codecov / codecov/patch

account_move_so_import/models/account_move.py#L65

Added line #L65 was not covered by tests
_(
'Line named "%s" was matched by more '
"than one partner while looking on SO by ref."
)
% line.name
)
if len(orders) == 1:
res["partner_id"] = orders[0].partner_id.id
return res
3 changes: 3 additions & 0 deletions account_move_so_import/readme/CONTRIBUTORS.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
* Joël Grand-Guillaume <[email protected]>
* Leonardo Pistone <[email protected]>
* Matthieu Dietrich <[email protected]>
4 changes: 4 additions & 0 deletions account_move_so_import/readme/DESCRIPTION.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
This module extends the functionality of account_move_base_import
to add support for completion rules based on Sale Orders. This was initially
part of the module account_statement_base_completion, but is now separate to
keep dependencies separate.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Loading