-
Notifications
You must be signed in to change notification settings - Fork 17
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 removing specific translations #2
Comments
An possible way to support this via the API:
In So the above call would translate internally to:
|
Hi @rijk , Currently, tap:i18n-db supports only basic operations that should be enough for a wide range of usecases. Since I think that for other users there might be more usecases that are not supported, and because I want to keep the API slim to keep it simple for new users and for maintenance reasons. I tend not to add new methods to this package. I think that the best thing to do here is to have your suggestion, that I definitely think will be useful for other developers, in an extension package for tap:i18n-db that will be maintained and tested separately. If with time will find that majority of tap:i18n-db needs that method we then either merge it to tap:i18n-db or have an umbrella package that will hold tap:i18n-db and its popular extensions. I encourage you to wrap your workaround to an extension package, if you'll do that I'll advertise the extension in the main README to make sure people will know about it. Also, it might open the gate for more extensions to be written by other tap:i18n-db users. That will benefit all of us. Thank you very much for helping to think how to improve tap:i18n-db, it's very appreciated. Daniel |
An alternative idea: do you think it would be possible to tap into the collection’s I know it sounds a little hacky, but I think the result experience would be it “just works”. Translations sticking around after you’ve deleted a property feels a little messy, and something the package should handle, ideally. |
I have run into a scenario where the
removeTranslation()
andremoveLanguage()
functionality is not sufficient. In my collection I'm storing options to a multiple choice question:This works perfectly. When removing an option though, it is very important that the translation is also removed. Otherwise, the interface may display deleted options, or incorrect translations based on the array key.
As the
remove*()
methods are using$unset
, I am unable to apply the kind of matching required for this. I currently work around this with a manual$pull
query, like this:While this works, I have to hardcode the
i18n
field name. It would be preferable to do this through the package API. I'll think about possible ways to implement this in the API.In addition, I would like to be able to simply invalidate all translations of this property, which I seem to not be able to do right now (every function requires a language argument). But I'll open a seperate issue for this.
The text was updated successfully, but these errors were encountered: