What are the Slack Archives?
It’s a history of our time together in the Slack Community! There’s a ton of knowledge in here, so feel free to search through the archives for a possible answer to your question.
Because this space is not active, you won’t be able to create a new post or comment here. If you have a question or want to start a discussion about something, head over to our categories and pick one to post in! You can always refer back to a post from Slack Archives if needed; just copy the link to use it as a reference..
Hi all, can someone tell me, where the translation for a super attributes key/value actually happens
Hi all,
can someone tell me, where the translation for a super attributes key/value actually happens?
I have currently two languages (en + ger) set up and therefore two entries for the abstract product in the
spy_product_abstract_localized_attributes
table. But the translation for a predefined value is defined in the attributes management section, right?
So i would suggest when i define here an attribute key “key.color” with the value “value.red” and i defined for the key for german “Farbe” and english “Color” and for the values “Rot” and “Red” that this gets displayed according to the selected language on my PDP. But it wont.
It seems that value is still the default “key.color” no matter what language selected.
When i look into the “spy_product_abstract_storage” table into the “data” fields json, i normally would suggest that here the magic already happened since this is what redis will get. But here is the key for both language entries the key “key.color” and “value.red” which should be Farbe or Color in my eyes (according to the language) …
So my question, where does the translation actually happen? Before publish? Or is there always the “technical key” published and the translation happens via translation service in Twig?
Any other suggestions?
Best regards and have a nice weekend
Comments
-
I belieeeeve back in the days at least, that attribute translations happened in glossary with some naming convention (prefixed with
attribute.
or similar). Can’t tell if that’s still the case (and if it’s 100% right memory), but probably it’s worth a look?0 -
I noticed a “spy_product_management_attribute_value” and a “spy_product_management_attribute_value_translation” table … but this part is missing for the keys … so, no “dynamic” translations for the keys here?
0 -
If I remember correctly, keys are translated via glossary key pattern:
product.attribute.<key>
.
See vendor/spryker/product-attribute/src/Spryker/Shared/ProductAttribute/ProductAttributeConfig.php::PRODUCT_ATTRIBUTE_GLOSSARY_PREFIX.0 -
ah okay … but when i create some attribute via attributefacade, this happens impliicit?
0 -
There we go, seems it’s still like that. Thanks Kay 🙂
0 -
Don't think that there's something happening implicitly. Pretty sure that you need to create the glossary key yourself.
0 -
ok, ill investigate … thanks a lot
0 -
Seems that a glossary key will be created implicitly, but it doesn't know what translation it should have. So yes, glossary key (spy_glossary_key) will be created, but the translation (spy_glossary_translation) is up to you.
0 -
Okay, the key seems to be translated, but what about the values? The value for the published product abstract in product abstract storage table is still “value.red” … it does not seem that the corresponding translation is considered from the attribute management backend. What i am missing? Best
0 -
As already mentioned in the product_abstract_localized_attributes table there are two entries, for each language one entry.
Should these entries already have the translated values or will the translation processed on another place?0 -
They'll be published as is, so if e. g. you'd like to get search suggestions in frontend for translated attribute values, you should have them translated in db already. At least this is what's working for me.
0 -
But how does the mapping to the “technical” value work? So for example when you define the color as a super attribute, i dont think, that the translated value in the db can be used for make a unique variant decision … so the only possibility i can imagine is, that in “spy_product_abstract” in “attributes” column, there is a key “key.color” with value “color.red” and in the “spy_product_abstract_localized_attributes” there is the key “key.color” (translated later in glossary) and value “Red” … or for the second language “key.color” and “Rot” …
0 -
Sorry, the attribute stuff is more confusing to me the more i have a more detailed look
0 -
😄
0 -
I double checked and it seems that its exactly as i described … but i do wonder now what the “default” translation means for a predefined value in backends attribute management? It gets never considered since there are already the translated values in the localized table …
0 -
I don't know about the default either. Maybe it is meant for cases where you're querying without passing a locale, e. g. via Glue API. Don't know if that's possible at all, it could also be a legacy field that hasn't been removed yet. Just guessing, maybe somebody from Spryker can enlighten us.
0
Categories
- All Categories
- 42 Getting Started & Guidelines
- 7 Getting Started in the Community
- 8 Additional Resources
- 7 Community Ideas and Feedback
- 65 Spryker News
- 879 Developer Corner
- 743 Spryker Development
- 84 Spryker Dev Environment
- 360 Spryker Releases
- 3 Oryx frontend framework
- 33 Propel ORM
- 68 Community Projects
- 3 Community Ideation Board
- 30 Hackathon
- 3 PHP Bridge
- 6 Gacela Project
- 22 Job Opportunities
- 3.2K 📜 Slack Archives
- 116 Academy
- 5 Business Users
- 370 Docker
- 551 Slack General
- 2K Help
- 75 Knowledge Sharing
- 6 Random Stuff
- 4 Code Testing
- 32 Product & Business Questions
- 68 Spryker Safari Questions
- 50 Random