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

[18.0][MIG] partner_invoicing_mode: Migration to 18.0. #1833

Open
wants to merge 23 commits into
base: 18.0
Choose a base branch
from

Conversation

chaule97
Copy link

@chaule97 chaule97 commented Nov 6, 2024

  • If a field is marked as readonly=True on the model, it won't be possible to import it through the Odoo import tool, so we avoid it as possible and define the readonly attribute on the views instead.

TDu and others added 21 commits November 4, 2024 15:55
[UPD] Update partner_invoicing_mode.pot

[UPD] README.rst

partner_invoicing_mode 16.0.1.0.1
Translated using Weblate (Spanish)

Currently translated at 100.0% (8 of 8 strings)

Translation: account-invoicing-16.0/account-invoicing-16.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-16-0/account-invoicing-16-0-partner_invoicing_mode/es/

[UPD] README.rst
Translated using Weblate (Italian)

Currently translated at 100.0% (8 of 8 strings)

Translation: account-invoicing-16.0/account-invoicing-16.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-16-0/account-invoicing-16-0-partner_invoicing_mode/it/
Allow to have a better extension mechanism when having multiple invoicing
modes.
The field one_invoice_per_order wasn't used correctly.

So, now, create invoices using the partner option by calling
the grouping option on sale orders
To improve flexibility, the invoicing grouping option could be different
on the sale order level than on the partner level.
As the read_group() can aggregate sale order ids per partner,
use the ids list instead.
…al field

As a company can have several different invoicing address, invoicing can occur at different
dates.
…tion

As validation jobs could last long time if there are plenty, ensure that
the wanted date is correctly set.
In order to be able to benefits from standard grouping function, override it
and add missing keys.

[UPD] Update partner_invoicing_mode.pot

[BOT] post-merge updates

Update translation files

Updated by "Update PO files to match POT (msgmerge)" hook in Weblate.

Translation: account-invoicing-16.0/account-invoicing-16.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-16-0/account-invoicing-16-0-partner_invoicing_mode/

Translated using Weblate (Italian)

Currently translated at 94.4% (17 of 18 strings)

Translation: account-invoicing-16.0/account-invoicing-16.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-16-0/account-invoicing-16-0-partner_invoicing_mode/it/

Translated using Weblate (Italian)

Currently translated at 100.0% (18 of 18 strings)

Translation: account-invoicing-16.0/account-invoicing-16.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-16-0/account-invoicing-16-0-partner_invoicing_mode/it/

Translated using Weblate (Spanish)

Currently translated at 100.0% (18 of 18 strings)

Translation: account-invoicing-16.0/account-invoicing-16.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-16-0/account-invoicing-16-0-partner_invoicing_mode/es/
Updated by "Update PO files to match POT (msgmerge)" hook in Weblate.

Translation: account-invoicing-17.0/account-invoicing-17.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-17-0/account-invoicing-17-0-partner_invoicing_mode/
Currently translated at 100.0% (18 of 18 strings)

Translation: account-invoicing-17.0/account-invoicing-17.0-partner_invoicing_mode
Translate-URL: https://translation.odoo-community.org/projects/account-invoicing-17-0/account-invoicing-17-0-partner_invoicing_mode/it/
Copy link
Member

@TDu TDu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actually, I think there is an issue with the sale dependency that is not installed...
image
So I would think the change on sale.order view is not applied ?

@TDu
Copy link
Member

TDu commented Nov 6, 2024

Actually, I think there is an issue with the sale dependency that is not installed... image So I would think the change on sale.order view is not applied ?
Finally installing the sale_management app and it works, so looks good 🤔
Yeah forget about my comment 🫨 sale was installed.

@@ -6,7 +6,8 @@
from freezegun import freeze_time

from odoo import fields
from odoo.tests.common import Form, TransactionCase
from odoo.tests import Form
from odoo.tests.common import TransactionCase
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why CommonPartnerInvoicingMove isn't depending on TransactionCase?
It implements setUpClass and calls super() which no parent class implements.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have updated CommonPartnerInvoicingMove depending on TransactionCase

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would ask first the author of this: cc @rousseldenis your opinion on this change?
This CommonPartnerInvoicingMove could be implemented this way to use it as a mixin by reverse dependencies, not as a common test class.

@chaule97
Copy link
Author

chaule97 commented Nov 8, 2024

Hello everyone, I have changed a little about readonly attribute in model and field

@chaule97 chaule97 requested a review from mmequignon November 20, 2024 10:33
@TDu
Copy link
Member

TDu commented Nov 22, 2024

base_partition has been mergedhttps://github.com/OCA/server-tools/pull/3077 that DON'T MERGE commit can be removed. Thanks

@chaule97 chaule97 force-pushed the 18.0-mig-partner_invoicing_mode branch from 2a89ba9 to a108a3f Compare November 22, 2024 17:53
@chaule97
Copy link
Author

base_partition has been mergedhttps://github.com/OCA/server-tools/pull/3077 that DON'T MERGE commit can be removed. Thanks

I have removed it

@@ -10,5 +10,4 @@ class ResCompany(models.Model):
invoicing_mode_standard_last_execution = fields.Datetime(
string="Last execution (standard)",
help="Last execution of standard invoicing.",
readonly=True,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure I understand this change.
I can't think of a reason why we'd want tthis field to be imported

_inherit = "account.move"

def _validate_invoice(self):
return self.sudo().action_post()
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure I understand why this method is needed.
Can't we call/delay action_post directly ?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it can keep queue job configurations

<record id="job_function_validate_invoice" model="queue.job.function">
        <field name="model_id" ref="account.model_account_move" />
        <field name="method">_validate_invoice</field>
        <field name="channel_id" ref="invoice_validation" />
        <field
            name="related_action"
            eval='{"func_name": "related_action_open_invoice"}'
        />
  </record>


invoicing_mode = fields.Selection([("standard", "Standard")], default="standard")
one_invoice_per_order = fields.Boolean(
default=False,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
default=False,

redundant

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have removed it

Comment on lines +26 to +30
def _update_next_invoice_date(self):
"""
This will update the next invoice date from the configuration set on
the partner if needed (not for standard invoicing_mode).
"""
return
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe I'm missing something..

What's the purpose of this method?
Seems rather useless..

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it's implemented in the other modules for each mode

@OCA-git-bot
Copy link
Contributor

This PR has the approved label and has been created more than 5 days ago. It should therefore be ready to merge by a maintainer (or a PSC member if the concerned addon has no declared maintainer). 🤖

@chaule97 chaule97 force-pushed the 18.0-mig-partner_invoicing_mode branch from a108a3f to 22282fa Compare December 31, 2024 01:56
@chaule97 chaule97 changed the title [18.0][MIG] : Migration partner_invoicing_mode to 18.0 [18.0][MIG] partner_invoicing_mode: Migration to 18.0. Jan 6, 2025
@chaule97 chaule97 force-pushed the 18.0-mig-partner_invoicing_mode branch from 22282fa to 7c97960 Compare January 6, 2025 03:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.