-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Search indices are not currency aware #2280
Comments
What abou this issue? @michaelbromley |
@kosarlukascz Hi, I've not had a chance to look deeply into this yet, but in principle yes this sounds like something that was overlooked with the changes to currency handling that was introduced in v2.0. @asonnleitner Currently the SearchIndexItem has a composite primary key on the We should consider performance/resource implications though, because if a shop has many currencies, then we will be duplicating lots of data. So perhaps a different storage approach could be explored, e.g. storing prices as a JSON column with prices in each currency encoded in a JSON object or an array. I'm open to ideas here. |
@michaelbromley In context of an international multi-vendor marketplace I think, when leveraging the E.g. Some sellers only add Products in $ and some other sellers in $ and EUR, and so on. I don't think a JSON column would be ideal in such a case? If this indeed would not be possible: |
@michaelbromley, sorry for the ping here. However, is there a current workaround for this since we're experiencing this issue in production environments. This is more a bug than a feature, no? PS: I should be able to help out on the primary key solution if that's the current way to go! |
Hi, There's no work-around right now other than implementing a customized version of the search plugin, the source of which is here: https://github.com/vendure-ecommerce/vendure/tree/fb0ea1326e5ee6cd240db146415dffc13af9ab9b/packages/core/src/plugin/default-search-plugin I'd like to see a solution to this which is backwards-compatible. I.e. it can be applied as an opt-in so that it is not a breaking change. This could be achieved by adding an opt-in flag to the DefaultSearchPlugin's init options, and then using the EntityMetadataModifier mechanism to dynamically modify the entity metadata for the /bounty $100 |
Hey @michaelbromley i am excited to work on it. Could you please assign this to me. |
sure @Rutik7066. I think you still need to add the "attempt" comment to get your attempt into Algora's system. This is a bit of a tricky one to get right in terms of preserving backward-compatibility. If you like you can open a draft PR and let me know if you want advice on any specific parts. |
Sure @michaelbromley i'll open draft pr.
|
What's the status on this issue 😅? We're planning on launching a new campaign which is live in GB and IRL, with this issue our prices will not show correctly in IRL (since GBP will be used instead of EUR). |
Working on a solution, only for the default search plugin which adds Will open a PR a bit later, it's def. not a robust solution, but will work for us for now :) |
The PR is open here :) - #3268 |
Is your feature request related to a problem? Please describe.
Following the new multi-currency support, the search strategies do not recognize the currency of the request context since they are unaware of it. I observed that when querying for a specific product, everything functions as expected. However, the search strategies might need an update to enable a currency-aware search.
Describe the solution you'd like
If the search strategies miss this functionality, they might need to be updated to facilitate a currency-aware search, including the Elasticsearch plugin. I'm willing to offer my help with this necessary changes if it's clear what needs to be done.
Describe alternatives you've considered
No alternatives have been considered.
Additional context
N/A
I have noticed several other currency-related issues.
availableCurrencyCodes = ["USD", "EUR"]
, and I wish to assign it to a channel where only EUR is available, the predefined value appears as USD. After assigning the product to the channel, the variant price is displayed in USD, even though the assigned channel does not support USD.Here is a quick video to showcase that: https://drive.google.com/file/d/1vVymbdNXyYx5THdr5RsH_tVd9_ir9sj1/view?usp=sharing
The text was updated successfully, but these errors were encountered: