Skip to content

Commit

Permalink
[18.0][MIG] account_avatax_oca: Migration to 18.0
Browse files Browse the repository at this point in the history
  • Loading branch information
kobros-tech committed Dec 5, 2024
1 parent b66d2ce commit 2f36ced
Show file tree
Hide file tree
Showing 17 changed files with 345 additions and 323 deletions.
302 changes: 152 additions & 150 deletions account_avatax_oca/README.rst

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion account_avatax_oca/__manifest__.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "Avalara Avatax Certified Connector",
"version": "17.0.1.3.1",
"version": "18.0.1.0.0",
"author": "Open Source Integrators, Fabrice Henrion,"
"Sodexis, Odoo Community Association (OCA)",
"summary": "Compute Sales Tax using the Avalara Avatax Service",
Expand Down
14 changes: 6 additions & 8 deletions account_avatax_oca/demo/avatax_demo.xml
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
<odoo>

<record id="avatax_customer" model="res.partner">
<field name="name">Washington Customer</field>
<field name="street">100 Ravine Ln Ne</field>
Expand All @@ -24,21 +23,20 @@

<record id="avatax_product_sku1" model="product.product">
<field name="name">Test Item P0000000</field>
<field name="detailed_type">product</field>
<field name="type">consu</field>
<field name="list_price">100.0</field>
<field name="tax_code_id" ref="avatax_product_taxcodeP" />
<field name="tax_code_id" ref="account_avatax_oca.avatax_product_taxcodeP" />
</record>
<record id="avatax_product_sku2" model="product.product">
<field name="name">Test Item NT</field>
<field name="detailed_type">product</field>
<field name="type">consu</field>
<field name="list_price">100.0</field>
<field name="tax_code_id" ref="avatax_product_taxcodeNT" />
<field name="tax_code_id" ref="account_avatax_oca.avatax_product_taxcodeNT" />
</record>
<record id="avatax_product_freight" model="product.product">
<field name="name">Common Carrier FR020100</field>
<field name="detailed_type">service</field>
<field name="type">service</field>
<field name="list_price">50.0</field>
<field name="tax_code_id" ref="avatax_product_taxcodeF" />
<field name="tax_code_id" ref="account_avatax_oca.avatax_product_taxcodeF" />
</record>

</odoo>
8 changes: 5 additions & 3 deletions account_avatax_oca/models/account_move.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import logging

from odoo import _, api, fields, models
from odoo import api, fields, models
from odoo.exceptions import UserError
from odoo.tests.common import Form
from odoo.tests import Form

_logger = logging.getLogger(__name__)

Expand Down Expand Up @@ -316,7 +316,9 @@ def _post(self, soft=True):
if not addr.date_validation:
# The Validate action will be interrupted
# if the address is not validated
raise UserError(_("Avatax address is not validated!"))
raise UserError(
self.env._("Avatax address is not validated!")
)
# We should compute taxes before validating the invoice
# to ensure correct account moves
# However, we can't save the invoice because it wasn't assigned a
Expand Down
8 changes: 4 additions & 4 deletions account_avatax_oca/models/account_tax.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
from math import copysign

from odoo import _, api, exceptions, fields, models
from odoo import api, exceptions, fields, models
from odoo.tools.float_utils import float_compare


Expand All @@ -25,7 +25,7 @@ def _get_avalara_tax_domain(self, tax_rate, doc_type):

@api.model
def _get_avalara_tax_name(self, tax_rate, doc_type=None):
return _("{}%*").format(str(tax_rate))
return self.env._("{}%*").format(str(tax_rate))

@api.model
def get_avalara_tax(self, tax_rate, doc_type):
Expand All @@ -38,7 +38,7 @@ def get_avalara_tax(self, tax_rate, doc_type):
tax_template = self.search(domain, limit=1)
if not tax_template:
raise exceptions.UserError(
_("Please configure Avatax Tax for Company %s:")
self.env._("Please configure Avatax Tax for Company %s:")
% self.env.company.name
)
# If you get a unique constraint error here,
Expand Down Expand Up @@ -105,7 +105,7 @@ def compute_all(
if avatax_amount is None:
avatax_amount = 0.0
raise exceptions.UserError(
_(
self.env._(
"Incorrect retrieval of Avatax amount for Invoice "
"%(avatax_invoice)s: product %(product.display_name)s, "
"price_unit %(-price_unit)f , quantity %(quantity)f"
Expand Down
22 changes: 14 additions & 8 deletions account_avatax_oca/models/avalara_salestax.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import logging

from odoo import _, api, fields, models
from odoo import api, fields, models
from odoo.exceptions import UserError

from .avatax_rest_api import AvaTaxRESTService
Expand Down Expand Up @@ -214,7 +214,7 @@ def create_transaction(
if not partner.customer_code:
if not avatax_config.auto_generate_customer_code:
raise UserError(
_(
self.env._(
"Customer Code for customer %(partner.name)s not defined.\n\n "
"You can edit the Customer Code in customer profile. "
'You can fix by clicking "Generate Customer Code" '
Expand All @@ -226,12 +226,14 @@ def create_transaction(

if not shipping_address:
raise UserError(
_("There is no source shipping address defined for partner %s.")
self.env._(
"There is no source shipping address defined for partner %s."
)
% partner.name
)

if not ship_from_address:
raise UserError(_("There is no Company address defined."))
raise UserError(self.env._("There is no Company address defined."))

if avatax_config.validation_on_save:
for address in [partner, shipping_address, ship_from_address]:
Expand All @@ -246,27 +248,31 @@ def create_transaction(
):
if not shipping_address.date_validation:
raise UserError(
_(
self.env._(
"Please validate the shipping address for the partner "
"%(partner.name)s."
)
)

# if not avatax_config.address_validation:
if not ship_from_address.date_validation:
raise UserError(_("Please validate the origin warehouse address."))
raise UserError(
self.env._("Please validate the origin warehouse address.")
)

if avatax_config.disable_tax_calculation:
_logger.info(
"Avatax tax calculation is disabled. Skipping %s %s.",
self.env._("Avatax tax calculation is disabled. Skipping %s %s."),
doc_code,
doc_type,
)
return False

if commit and avatax_config.disable_tax_reporting:
_logger.warning(
_("Avatax commiting document %s, but it tax reporting is disabled."),
self.env._(
"Avatax commiting document %s, but it tax reporting is disabled."
),
doc_code,
)

Expand Down
20 changes: 11 additions & 9 deletions account_avatax_oca/models/avatax_rest_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
import pprint
import socket

from odoo import _, fields, tools
from odoo import fields, tools
from odoo.exceptions import UserError

_logger = logging.getLogger(__name__)
Expand Down Expand Up @@ -45,7 +45,7 @@ def __init__(
)
except NameError as exc:
raise UserError(
_(
self.env._(
"AvataxClient is not available in your system. "
"Please contact your system administrator "
"to 'pip3 install Avalara'"
Expand Down Expand Up @@ -75,7 +75,7 @@ def get_result(self, response, ignore_error=None):
if w_message.get("severity") in ("Error", "Exception"):
if w_message.get("refersTo", "").startswith("Address"):
raise UserError(
_(
self.env._(
"AvaTax: Warning AvaTax could not validate the"
" address:\n%s\n\n"
"You can save the address and AvaTax will make an"
Expand All @@ -95,7 +95,7 @@ def get_result(self, response, ignore_error=None):
)
elif w_message.get("refersTo") == "Country":
raise UserError(
_(
self.env._(
"AvaTax: Notice\n\n Address Validation for this"
" country not supported. "
"But, Avalara will still calculate global tax"
Expand All @@ -121,7 +121,7 @@ def get_result(self, response, ignore_error=None):
w_message.get("description", "")
)
message += "\n Severity: " + str(w_message.get("severity"))
raise UserError(_(message))
raise UserError(self.env._(message))
return result

def ping(self):
Expand All @@ -130,15 +130,17 @@ def ping(self):
if self.is_log_enabled:
_logger.info(pprint.pformat(res, indent=1))
if not res.get("authenticated"):
raise UserError(_("The user or account could not be authenticated"))
raise UserError(
self.env._("The user or account could not be authenticated")
)
return res

def validate_rest_address(
self, street, street2, city, zip_code, state_code, country_code
):
if self.config.disable_address_validation:
raise UserError(
_(
self.env._(
"The AvaTax Address Validation Service"
" is disabled by the administrator."
" Please make sure it's enabled for the address validation"
Expand All @@ -147,7 +149,7 @@ def validate_rest_address(
supported_countries = [x.code for x in self.config.country_ids]
if country_code and country_code not in supported_countries:
raise UserError(
_(
self.env._(
"The AvaTax Address Validation Service does not support"
" this country in the configuration,"
" please continue with your normal process."
Expand Down Expand Up @@ -234,7 +236,7 @@ def get_tax(
"""
if not origin.street:
raise UserError(
_(
self.env._(
"Please set the Company Address "
"in the partner information and validate. "
"We are checking against the first line of the address "
Expand Down
13 changes: 9 additions & 4 deletions account_avatax_oca/models/partner.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
import time
from random import random

from odoo import _, api, fields, models
from odoo import api, fields, models
from odoo.exceptions import UserError

from .avatax_rest_api import AvaTaxRESTService
Expand All @@ -22,7 +22,7 @@ class ResPartner(models.Model):
def _onchange_property_exemption_contry_wide(self):
if self.property_exemption_country_wide:
message = (
_(
self.env._(
"Enabling the exemption status for all states"
" may have tax compliance risks,"
" and should be carefully considered.\n\n"
Expand All @@ -31,7 +31,12 @@ def _onchange_property_exemption_contry_wide(self):
" for every state this Partner may have transactions."
),
)
return {"warning": {"title": _("Tax Compliance Risk"), "message": message}}
return {
"warning": {
"title": self.env._("Tax Compliance Risk"),
"message": message,
}
}

date_validation = fields.Date(
"Last Validation Date",
Expand Down Expand Up @@ -101,7 +106,7 @@ def check_exemption_number(self):
partner.property_exemption_code_id or partner.property_exemption_number
):
raise UserError(
_(
self.env._(
"Please enter either Exemption Number or Exemption Code"
" for marking customer as Exempt."
)
Expand Down
7 changes: 4 additions & 3 deletions account_avatax_oca/models/res_company.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import logging

from odoo import _, models
from odoo import models

_LOGGER = logging.getLogger(__name__)

Expand All @@ -18,11 +18,12 @@ def get_avatax_config_company(self):
)
if len(res) > 1:
_LOGGER.warning(
_("Company %s has too many Avatax configurations!"),
self.env._("Company %s has too many Avatax configurations!"),
self.display_name,
)
if len(res) < 1:
_LOGGER.warning(
_("Company %s has no Avatax configuration."), self.display_name
self.env._("Company %s has no Avatax configuration."),
self.display_name,
)
return res and res[0]
2 changes: 2 additions & 0 deletions account_avatax_oca/readme/CONTRIBUTORS.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,5 @@
- Murtuza Saleh
- Sodexis
- Atchuthan Ubendran
- Kencove (<https://www.kencove.com>)
- Mohamed Alkobrosli \<<malkobrosly@kencove.com>\>
Loading

0 comments on commit 2f36ced

Please sign in to comment.