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][ADD] pos_container_deposit #1278

Open
wants to merge 6 commits into
base: 16.0
Choose a base branch
from
Open

Conversation

hbrunn
Copy link
Member

@hbrunn hbrunn commented Dec 19, 2024

migration of #616 with @legalsylvain's comments applied

Copy link
Contributor

@legalsylvain legalsylvain left a comment

Choose a reason for hiding this comment

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

Hi @hbrunn. Thanks a lot for porting and finishing this module ! (I need it in V16 in a few monthes ;-))

Some remarks inline + functional review.

Functional review :

problem 1 :
set consign as not available in PoS
set product as available in pos + consign

when selecting the product, there is an not handled error.

image

Proposal : (not sure)

  • at least add a more sexy message in the Javascript. "The product X has a consign, but it is not available in the point of sale, please make the consign available in the PoS".
  • (alternatively, load silently the consign, I think it's possible dynamicaly in recent version).
  • maybe (not sure), add a constrains, when setting consign on product, if consign are not available in PoS.

Problem 2 :

  • select a product in PoS : OK.

image

  • click a second time on the product : KO.

image

pos_deposit/views/product_template.xml Outdated Show resolved Hide resolved
pos_deposit/models/product_template.py Outdated Show resolved Hide resolved
pos_deposit/models/product_template.py Outdated Show resolved Hide resolved
@hbrunn
Copy link
Member Author

hbrunn commented Dec 19, 2024

@legalsylvain thanks for your comprehensive review, took all your points.

I took the liberty to fix you quoting yourself which messed up runboat ;-)

@legalsylvain
Copy link
Contributor

legalsylvain commented Dec 19, 2024

I took the liberty to fix you quoting yourself which messed up runboat ;-)

oh thanks !

Gui.showPopup("ErrorPopup", {
title: _t("Deposit not available"),
body: _t(
"The product is configured as having a deposit but the deposit product is not available in POS."
Copy link
Contributor

Choose a reason for hiding this comment

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

UX nitpicking : I guess product.deposit_product_id[1] contains the name of the deposit. we could add it in the message, so the user know directly which product he has to enable for the PoS.

@@ -0,0 +1 @@
- If the screen refreshes or session is reopened, the link between product and container is lost, so the quantities can get out of sync. This is not something that happens often and can be 'repaired' by removing and re-adding a product to the order.
Copy link
Contributor

@legalsylvain legalsylvain Dec 19, 2024

Choose a reason for hiding this comment

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

I didn't faced that issue. I mean

  • open PoS
  • Add a product (it adds a consign)
  • set quantity = 33 (it set qty = 33 on consign)
  • refresh
  • set quantity = 50 on product (it set qty = 50 on consign).

What is the "bug" / "limitation" described here ?

Copy link
Member Author

Choose a reason for hiding this comment

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

ah, that's a leftover from v13

Copy link
Contributor

@legalsylvain legalsylvain left a comment

Choose a reason for hiding this comment

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

code review and test. LGTM. Thanks !

@hbrunn
Copy link
Member Author

hbrunn commented Dec 19, 2024

@legalsylvain curious about your take on discussion with the customer:

currently you can edit the deposit product line independently of the line it's a deposit for, I was thinking about doing this because a customer buys 10 bottles and returns 5, then you don't need to scan 5 negative deposit bottles, but just edit the quantity of the deposit. Do you consider this a valid use case, or should we rather not allow editing the deposit line at all?

@legalsylvain
Copy link
Contributor

currently you can edit the deposit product line independently of the line it's a deposit for, I was thinking about doing this because a customer buys 10 bottles and returns 5, then you don't need to scan 5 negative deposit bottles, but just edit the quantity of the deposit. Do you consider this a valid use case, or should we rather not allow editing the deposit line at all?

Yes. return and purchase consign in a single sale is a common use case, at least in my business : For exemple, the groceries sell beer in returnable bottles. So regularly, the customer comes with an empty bottle, and leaves with a full one.

But I have another questions. (not blocking point).

  1. In this exemple (beer in returnable bottles), I'm not sure how to initialize consign stock. I mean : some suppliers doesnt mention the sell of the consign. So if I purchase beer and sell beer + consign, consign stock will be negative. Do you face similar question ? do you think develop some pos_deposit_purchase could make sense to automatically increment consign stock ?

  2. In theory, we could imagine use this feature also on sale.order ? (something like a button "compute Consigns" on draft sale.order, present, if the sale.order contains lines with products with deposit. In that case, we could imagine some split of the module. product_deposit / sale_deposit / pos_deposit. What do you think ? (some split or refactoring can be done in a second time, if needed).

  3. Finally, about the naming, maybe there is some conflict regarding "deposit" word.

There are first :

If I understand correctly, the 4 modules mentioned above implement something similar to your implementation in the product level, but in a more complex (or complete) manner, with packaging.

Also there are :

But I'm not sure to understand very well the usage of those modules

(Finally, there is https://github.com/OCA/account-financial-tools/tree/16.0/account_cash_deposit but this is a very disctinct topic)

All this to say that the OCA is full of “deposit” modules that talk about a variety of things. I don't have any clear proposals on this subject though.

thanks for reading.

@thomaspaulb
Copy link
Contributor

@legalsylvain Currently in the two installations where this is used, they have manually created "negative deposit products" that mirror the regular ones. In such a case, it makes sense to make the "automatic" POS order line readonly and locked to the number of products, eg 10 beer always comes with 10 bottles, and if bottles come back, it's going to be a separate order line with 5 "return bottles". This is of course not good for stockkeeping, but in their case they don't care because they've set the containers as consumables and just don't count stock. Though for installations that do keep stock it can work by selling negative amounts of containers on a separate line, I've tested this in 16.0 and it also seems to be possible.

In your opinion should we:

  1. Force it in this way, so locking the deposit order line and forcing to use a second one if containers come back
  2. Allow a different amount product vs container (though then our customer will complain that their process has changed)
  3. Make it a configuration option, so both of us can be happy?

PS. About the *_container_deposit modules, that's interesting. Perhaps they should be integrated. We don't have the budget for it in this project, but later in the year the second customer is migrating so perhaps the discussion can be reopened.

@legalsylvain
Copy link
Contributor

Though for installations that do keep stock it can work by selling negative amounts of containers on a separate line, I've tested this in 16.0 and it also seems to be possible.

I don't understand how you can "add a new negative line". If I click on the consign, it readd a quantity 1 to the existing line. It doesn't create a new line. Or do you use this module https://github.com/OCA/pos/tree/16.0/pos_order_new_line ?
Or I missed something ?

Allow a different amount product vs container (though then our customer will complain that their process has changed)

hum.... you have to in any case. if product Test and Test 2 use the same consign product, quantity of line "Test" / "Test 2" and "consign" are different. Don't you think ?

screenshot of the current runboat :

image

Sorry If I missed something.

@thomaspaulb
Copy link
Contributor

I don't understand how you can "add a new negative line".

True but i was talking the case where we decide to lock the existing consign product line to readonly state, and make sure that Odoo adds a new line instead? In that case, the newly added line can be made a negative one.

you have to in any case. if product Test and Test 2 use the same consign product, quantity of line "Test" / "Test 2" and "consign" are different.

.... yes, I didn't think of that but you're right, they add up in the same line. Though even then, we can have the both options of A) locking that particular line and having it governed only by the amounts on the product lines that use that line, or B) allowing it to be manually edited. I think the main problem with B is that it requires quite the amount of math in the head of the salesperson in the case where people bring back crates/bottles and it's easy to make mistakes? Anyway, it still remains my question to you whether you would be in favour of A, B or a configuration option deciding between the both.

@hbrunn While testing with two products (say X, Y) using the same consign/deposit product (P) I found bugs though:

  1. When product X is added and then product X is added again, it creates an extra line for product X. Not sure why it does that, I would expect Odoo to add to the existing line. In any case, then the deposit line is not increased, probably because it tries to keep the second line in sync with the deposit product line and forgets about the first.
  2. When product X is added and product Y is added we then have 2xP. But if I then remove product Y, the full line with 2P is removed. Instead it should reduce by 1

@legalsylvain
Copy link
Contributor

True but i was talking the case where we decide to lock the existing consign product line to readonly state, and make sure that Odoo adds a new line instead? In that case, the newly added line can be made a negative one.

ah. yes. indeed.

Well, for me :

  • this module as it, can be merged now or after introduction or extra feature.
  • if you introduce "lock" mechanism, it's better if you make it as an option. If no, no problem, I can do it in a second time when I'll use this module in a few monthes.
  • Regarding the naming, maybe "pos_container_deposit" could be a better option, so we could imagine to split / make glue module like product_container_deposit, sale_container_deposit and purchase_container_deposit. If we keep "pos_deposit", create "purchase_deposit" will not be possible, because the name is already used. In the same time container_deposit looks different of the other implementation that contains "package_container_deposit".

@denniiiiis
Copy link

I agree with tom's suggestion.

  • Force it in this way, so locking the deposit order line and forcing to use a second one if containers come back
  • Allow a different amount product vs container (though then our customer will complain that their process has changed)
  • Make it a configuration option, so both of us can be happy?

Regarding the issue with calculation of number of deposits products X.

At the moment we have in our v8 version;

  • per product odoo adds a line of deposit product, which means if product X and Y uses the same deposit product odoo Pos will show (1x product X, 1x deposit 0,25, 2x product Y, 2x deposit 0,25) --> I would prefer this and is if I'm not mistaken common practice with large retailers (Albert Heijn / Jumbo / etc). It is easier to understand the receipt for customers/employees.
  • first product, second line deposit
  • if you change the amount of products, deposit automatically follows
  • if a customer returns a deposit product (sometimes customer only returns deposit and doesn't buy a new product with deposits)

@thomaspaulb
Copy link
Contributor

@denniiiiis So to clarify, your preference would be this:

(...) locking the deposit order line and forcing to use a second one in case containers come back

And not this, unless it's an option that can be switched off:

Allow a different amount product vs container

Then also, your preference would be that each new product that has a matching deposit has their own, paired and separate deposit line, which is locked.

So in the end if people buy 5 milk, 5 cola and also return 3 bottles, it would look like this:

MILK 5
bottle 5
COLA 5
bottle 5
bottle -3

Correct?

@thomaspaulb
Copy link
Contributor

@legalsylvain If we then make it in this way and rename the module, would you add your own process as an option that can be selected, later this year? Or would you perhaps explain your users to prefer this option also (I agree with Dennis that it's both easier for the cashier and clearer for everyone)

@legalsylvain
Copy link
Contributor

@legalsylvain If we then make it in this way and rename the module, would you add your own process as an option that can be selected, later this year? Or would you perhaps explain your users to prefer this option also (I agree with Dennis that it's both easier for the cashier and clearer for everyone)

I'm totally agree with the following solution.

MILK 2
bottle 2
COLA 5
bottle 5
bottle -3

In fact, it will be better :

bottle 2
MILK 2
bottle 5
COLA 5
bottle -3

I mean, when we scan a product, the consign is added before the product added. Otherwise, if the user want to change price, quantity, etc., he will change the price / quantity of the consign, that is not what he want. Don't you think ?

Otherwise, LGTM.

For the renaming, sorry for the extra work. I think that it's better to rename now than once merged in OCA repo.

@denniiiiis
Copy link

@legalsylvain, I got your point regarding the order and see the benefits.
But in our case we barely adjust prices of these kind of items and we have the order the other way around.

@thomaspaulb / @hbrunn , maybe we could make it (order) a configuration option as well?

@thomaspaulb
Copy link
Contributor

@legalsylvain

If after scanning MILK, bottle comes automatically but the focus jumps back to MILK and the bottle line is locked / can't be edited, does your order argument still apply?

@legalsylvain
Copy link
Contributor

I think it's OK in that case.
Anyway, hard to know if the cashiers will find it ergonomic.
Maybe ill do some adjustement in a second time.

@hbrunn
Copy link
Member Author

hbrunn commented Dec 26, 2024

followed up everything here and added js tests

@thomaspaulb
Copy link
Contributor

Should the title of the MR rather be [ADD][16.0] pos_container_deposit, since the 13.0 one was never merged and likely wont be

Copy link
Contributor

@thomaspaulb thomaspaulb left a comment

Choose a reason for hiding this comment

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

works well!

@hbrunn hbrunn changed the title [16.0][MIG] pos_deposit [16.0][ADD] pos_container_deposit Dec 26, 2024
@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). 🤖

pos_container_deposit/models/product_template.py Outdated Show resolved Hide resolved
pos_container_deposit/static/src/js/models.js Outdated Show resolved Hide resolved
class TestPosContainerDeposit(TestPointOfSaleHttpCommon):
def run_tour(self):
self.main_pos_config.open_ui()
self.start_tour(
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 surprised about this codecov message here

Codecov
/ codecov/patch

pos_container_deposit/tests/test_pos_container_deposit_frontend.py#L9-L10

Added lines #L9 - L10 were not covered by tests

These don't seem to be running in our CI 🤔

Copy link
Member Author

Choose a reason for hiding this comment

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

all of them are skipped because we don't have the expected coa - looks like installing l10n_fr is causing this, because this suppresses installing l10n_generic_coa which the base class checks for.

Maybe we should make pos_ticket_extra_company_info_l10n_fr a rebel module for this reason?

Copy link
Member Author

Choose a reason for hiding this comment

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

Copy link
Contributor

Choose a reason for hiding this comment

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

Maybe we should make pos_ticket_extra_company_info_l10n_fr a rebel module for this reason?

no problem with such exclusion.
Note: It's a temporary problem because l10n_generic_coa disappeared in V18, and it's better as it.

@rousseldenis
Copy link
Contributor

rousseldenis commented Jan 21, 2025

Hi all, I come late but FYI, I did this module : https://github.com/OCA/product-pack/tree/14.0/pos_product_pack

That is a more generic approach (but more complex) that allows to define deposit product as a component of the product pack.

But that approach is using a process that works in backend too without being specific for POS (only pos related code)

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.

7 participants