diff --git a/delivery_deliverea/__manifest__.py b/delivery_deliverea/__manifest__.py
index 2fb6a2f959..a8016e43f4 100644
--- a/delivery_deliverea/__manifest__.py
+++ b/delivery_deliverea/__manifest__.py
@@ -13,6 +13,7 @@
"depends": [
"delivery_state",
"delivery_package_number",
+ "stock_quant_package_dimension",
],
"external_dependencies": {"python": ["unidecode"]},
"data": [
diff --git a/delivery_deliverea/data/product_packaging_data.xml b/delivery_deliverea/data/product_packaging_data.xml
index 633c082dae..8670c636fb 100644
--- a/delivery_deliverea/data/product_packaging_data.xml
+++ b/delivery_deliverea/data/product_packaging_data.xml
@@ -8,5 +8,6 @@
10
20
2
+ 2
diff --git a/delivery_deliverea/models/delivery_carrier.py b/delivery_deliverea/models/delivery_carrier.py
index aefb9be9a6..4a5df12d10 100644
--- a/delivery_deliverea/models/delivery_carrier.py
+++ b/delivery_deliverea/models/delivery_carrier.py
@@ -310,37 +310,65 @@ def _get_deliverea_parcel_items(self, picking):
)
return items
- def _get_deliverea_parcel_info(self, carrier, picking):
- parcels = []
- num_packages = picking.number_of_packages or 1
- default_package = carrier.deliverea_default_packaging_id
- if (
- not default_package.max_weight
- or not default_package.height
- or not default_package.width
- or not default_package.packaging_length
+ def _get_package_weight(self, package):
+ return package.weight_uom_id._compute_quantity(
+ package.pack_weight, self.env.ref("uom.product_uom_kgm")
+ )
+
+ def _get_package_length(self, package, field):
+ return package.length_uom_id._compute_quantity(
+ getattr(package, field), self.env.ref("uom.product_uom_cm")
+ )
+
+ def assert_default_values(self, default_package):
+ if not all(
+ (
+ default_package.base_weight,
+ default_package.height,
+ default_package.width,
+ default_package.packaging_length,
+ )
):
raise UserError(
_(
- "The max_weight, height, width and length values must be defined"
+ "The base_weight, height, width and length values must be defined"
" in the package associated with the carrier."
)
)
- for i in range(num_packages):
+
+ def _get_deliverea_parcel_info(self, carrier, picking):
+ parcels = []
+ num_packages = picking.number_of_packages or 1
+ default_package = carrier.deliverea_default_packaging_id
+ warehouse_country_id = (
+ picking.picking_type_id.warehouse_id.partner_id.country_id
+ )
+ self.assert_default_values(default_package)
+ for package in picking.package_ids:
parcels.append(
{
- "weight": default_package.max_weight,
- "height": default_package.height,
- "width": default_package.width,
- "length": default_package.packaging_length,
+ "weight": self._get_package_weight(package)
+ or default_package.base_weight,
+ "height": self._get_package_length(package, "height")
+ or default_package.height,
+ "width": self._get_package_length(package, "width")
+ or default_package.width,
+ "length": self._get_package_length(package, "pack_length")
+ or default_package.packaging_length,
}
)
- if (
- i == 0
- and picking.picking_type_id.warehouse_id.partner_id.country_id.code
- != picking.partner_id.country_id.code
- ):
- parcels[0].update({"items": self._get_deliverea_parcel_items(picking)})
+ if not picking.package_ids:
+ for __ in range(num_packages):
+ parcels.append(
+ {
+ "weight": default_package.base_weight,
+ "height": default_package.height,
+ "width": default_package.width,
+ "length": default_package.packaging_length,
+ }
+ )
+ if warehouse_country_id.code != picking.partner_id.country_id.code:
+ parcels[0].update({"items": self._get_deliverea_parcel_items(picking)})
return parcels
def _get_service_attributes(self, carrier, service):
diff --git a/delivery_deliverea/tests/test_delivery_deliverea.py b/delivery_deliverea/tests/test_delivery_deliverea.py
index 4f2c77e576..af6b0c793c 100644
--- a/delivery_deliverea/tests/test_delivery_deliverea.py
+++ b/delivery_deliverea/tests/test_delivery_deliverea.py
@@ -457,3 +457,54 @@ def test_13_get_return_label(self):
]
)
self.assertTrue(attachment)
+
+ def test_14_get_default_packages(self):
+ default_package = self.carrier.deliverea_default_packaging_id
+ packages = self.carrier._get_deliverea_parcel_info(self.carrier, self.picking)
+ self.assertEqual(len(packages), 2)
+ self.assertTrue(packages[0].get("items"))
+ for package in packages:
+ self.assertEqual(package.get("weight"), default_package.base_weight)
+ self.assertEqual(package.get("width"), default_package.width)
+ self.assertEqual(package.get("height"), default_package.height)
+ self.assertEqual(package.get("length"), default_package.packaging_length)
+
+ def test_15_get_data_packages(self):
+ self.picking.package_ids = [
+ (
+ 0,
+ 0,
+ {
+ "name": "Test Package",
+ "pack_weight": 1,
+ "width": 1,
+ "height": 1,
+ "pack_length": 1,
+ },
+ ),
+ (
+ 0,
+ 0,
+ {
+ "name": "Test Package 2",
+ "pack_weight": 0,
+ "width": 0,
+ "height": 0,
+ "pack_length": 0,
+ },
+ ),
+ ]
+ # Package length uom is mm, weight uom is kg
+ packages = self.carrier._get_deliverea_parcel_info(self.carrier, self.picking)
+ self.assertEqual(len(packages), 2)
+ self.assertEqual(packages[0].get("weight"), 1.0)
+ self.assertEqual(packages[0].get("height"), 0.1)
+ self.assertEqual(packages[0].get("width"), 0.1)
+ self.assertEqual(packages[0].get("length"), 0.1)
+ self.assertTrue(packages[0].get("items"))
+ # Check default values
+ default_package = self.carrier.deliverea_default_packaging_id
+ self.assertEqual(packages[1].get("weight"), default_package.base_weight)
+ self.assertEqual(packages[1].get("width"), default_package.width)
+ self.assertEqual(packages[1].get("height"), default_package.height)
+ self.assertEqual(packages[1].get("length"), default_package.packaging_length)