-
-
Notifications
You must be signed in to change notification settings - Fork 18
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
Round to 0 issues when converting lightweight products from lb to gram #126
Comments
Thanks for the feedback on this one! We're somewhat at the mercy of the item interface being an I'll do some testing. |
@engram-design any updates on this? I have like 5000 lightweight products not showing rates from DHL, 0.086kg is being rounded to 0 for me |
I'm not entirely sure what sort of action to take here. We can't rightly round-up weights, as that produces invalid weight data, particularly for large orders, as you've both mentioned (5k, or 50k). What I don't immediately understand though, is that if you're purchasing 50k 0.001 lb, is this an issue? That's 50 lb. On the DHL end with @hassanmah the same stands. If we round up to even 0.1kg, order 5k products, that's 430kg. We already check if the packed box is being rounded down to One immediate change I could make is to make this unit-aware. Right now, it's |
One way around this I found that convert KGs into grams for box packer to process, then convert back to KG for the DHL payload, this now brings back accurate rates |
I've gone ahead and made this change with setting the minimum weight for a box to 1g, which is them converted into the respective weight unit for the provider, which I'm hopeful should help. And the conversation should already be happening, as the box packed takes whatever unit you have your products defined as, convert to metric (g/mm), then to the units the provider requires (for DHL, that's kg/cm). |
Describe the bug
Hi again! I've run into another subtle issue with the same client who sells super small, lightweight products.
They have some products that weigh less than
0.001 lb = 0.454 g
. The box packing process converts those weights to grams and stores them as an int. Due to how PHP rounds floats to integers, Item objects end up with a zero weight, and can produce issues with Providers (at least with FedEx Freight in our client's case).Thanks to the custom packer from #123, I'm able to clamp those Item objects to weigh at least one gram. But, that can end up more than doubling the total weight (especially noticeable when ordering 50k products).
I don't know if there is an elegant workaround... since the Box Packer's Item interface expects grams as
int
.In my very specific use case from #123, I'm merging similar Item objects together (adding up weight and value) and avoiding timeouts.
If I could somehow access the "true" weight as part of that merging step, I would be able to arrive at more accurate total weight.
Thought I'd share in case you had any insights. But don't feel like you need to spend a ton of time thinking about it.
Steps to reproduce
Here's how I produced the FedEx freight specific error in the screenshot.
So far I've only seen actual FedEx errors when the order order qualifies for FedEx freight.
For normal FedEx options, it doesn't seem to care about the weight being zero.
But either way... the weight is inaccurate.
Craft CMS version
4.7.0
Plugin version
3.1.6
Multi-site?
Yes
Additional context
No response
The text was updated successfully, but these errors were encountered: