-
Notifications
You must be signed in to change notification settings - Fork 7
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
Support Magento2 as Storage Format #14
Comments
Hi there thank you for this this is because of the key names. I never saw key names of translations that look like this: "Searching...". thank you |
Yeah, in Magento we don't use keys for translations, we use the actual English phrases that are used in the application, and those phrases are then translated in different languages via csv files (one csv file per locale, where the english phrase is in the first column and the translated phrase in the second column, here's an example should you be curious). Anyway, if you believe this is not something your tool should support for json files, then no problem, I'm just doing some experiments at the moment to see if the tool can do what we would need in our specific case. If it turns out to be useful and we want to invest some time into it, maybe I can try to make some PR's to add support for Magento2 csv files. But no promises yet 😄 |
ah ok now it makes sense this can totally be done with phpunuhi what is missing for you is a CSV storage format. also, all translations are in 1 file...so theres the same approach with INI at the moment, where its possible to define the iniSection of a locale. so in your case it would also be the same file, and one needs to provide the csvColumn you know what i mean? |
aa sry, in that special case...maybe a special magento format :D |
It indeed sounds like an idea is shaping here However, the Magento case is even more complex, because there are a lot of different layers of translations involved where we can have parent and child translations packs where childs can append and overwrite translations from parents.
What we would need is that all those different layers are being merged together, with the correct way of overwriting translations, and at the end we would need to compare the result between different languages to be able to find missing ones, and output those missing ones in a specific file (usually the custom language pack inside a project) So this sounds quite complex and might be a bit out of scope of this package here. But the package here definitely contains already some nice functionalities that we could use after some quick testing! |
i dont think its out of scope, not really so in shopware 6 for example there are 2 options im not really good with magento, but i think its possible (and i need to learn it a bit more, but i know a few people that could also help). i hope that makes sense a bit? if so, then I would just rename this ticket to "support magento" :D ? |
Okay great Here's a proposal, not really thought through but might be a good start. ...
<set name="Storefront">
<locales>
<format>
<magento2>
<output name="de_DE">
/path/to/the/custom/translation/file/for/the/project/de_DE.csv
</output>
<output name="en_US">
/path/to/the/custom/translation/file/for/the/project/en_US.csv
</output>
</magento2>
</format>
<locale name="de_DE">
<file sortOrder="1">
/path/to/base/language/pack/de_DE.csv
</file>
<file sortOrder="2">
/path/to/vendor/language/pack/de_DE.csv
</file>
<file sortOrder="3">
/path/to/modules/with/glob/support/**/i18n/de_DE.csv
</file>
<file sortOrder="4">
/path/to/the/custom/translation/file/for/the/project/de_DE.csv
</file>
</locale>
<locale name="en_US">
<file sortOrder="1">
/path/to/base/language/pack/en_US.csv
</file>
<file sortOrder="2">
/path/to/vendor/language/pack/en_US.csv
</file>
<file sortOrder="3">
/path/to/modules/with/glob/support/**/i18n/en_US.csv
</file>
<file sortOrder="4">
/path/to/the/custom/translation/file/for/the/project/en_US.csv
</file>
</locale>
</locales>
</set>
... So things that might be important:
This is just a proposal, no idea how difficult it would be to implement this with what is already here, without having to rewrite a lot of code all over the place. Still investigating on our side, I need to propose this to some team members and see what they think. If approved, we can try to help out with building this feature request. |
hi there dont be worried that i didnt answer yet |
Small update from our part, because we've decided to take another approach and a colleague of mine already finished an initial working prototype. Unfortunately it's in private code part of a bigger project we can't open source. So for now we won't need this functionality anymore from the phpunuhi project. You can close the request if you think it won't be helpful to other people. |
Hi ok thanks for letting me know, thanks for your input on this |
Hi there
Update: the initial question is no longer relevant now that we've changed the title in this issue
Just playing around, we are using csv files for translations (used by Magento2 e-commerce) which this tool doesn't support yet, but out of curiosity I quickly converted them to json to be able to play around a bit with this tool to see how well it works and if it would be useful for us or not.
But I noticed something strange when dots (
.
) exist in the translations:Here's an example json file:
After running
vendor/bin/phpunuhi fix:structure
it turns this json into something very strange:It looks like it converts a
.
character into a new key-value each time, which is kind of unexpected.Or am I missing some configuration setting somehow?
Thanks!
The text was updated successfully, but these errors were encountered: