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

Translating a whole struct does not use the fallback if the locale is configured but translation is missing #10

Open
tozz opened this issue Aug 9, 2024 · 6 comments

Comments

@tozz
Copy link

tozz commented Aug 9, 2024

I have a very basic setup (anonymized a bit)

defmodule X.Cldr do
  use Cldr,
    locales: [:en, :sv],
    providers: [Cldr.Number, Cldr.Calendar, Cldr.DateTime, Cldr.Trans],
    default_locale: :en
end

I then want to translate a struct but it fails if the locale has been configured but the translation is missing.

    test = %X.Y{
      title: "a title",
      translations: %X.Y.Translations{}
    }

    test_sv = Cldr.Trans.Translator.translate(test, :sv)
    test_sv.title == nil

If I use a locale that is not configured the fallback works as expected.

    test = %X.Y{
      title: "a title",
      translations: %X.Y.Translations{}
    }

    test_de = Cldr.Trans.Translator.translate(test, :de)
    test_de.title == "a title"

And finally, when using a fallback chain it also works as expected.

    test = %X.Y{
      title: "a title",
      translations: %X.Y.Translations{}
    }

    test_sv = Cldr.Trans.Translator.translate(test, [:sv, :en])
    test_sv.title == "a title"

Giving the field also works as expected.

    test = %X.Y{
      title: "a title",
      translations: %X.Y.Translations{}
    }

    Cldr.Trans.Translator.translate(test, :title, :sv)
    # "a title"

So there's clearly some kind of mismatch here, or I am not reading the docs correctly. I'm fine with the behavior now that I understand why it happens, but it took a while, is it a bug or expected behaviour?

@kipcole9
Copy link
Contributor

kipcole9 commented Aug 9, 2024

@tozz, thanks for the very complete report, greatly appreciated.

You are seeing the behaviour as implemented. But I'm not sure either if it's the right behaviour. Fair to say the user population of this lib isn't high so it's hard to get a feeling for expectations. At minimum the documentation clearly needs improvement.

Part of the challenge is that sometimes the translation is resolved in a database query and sometimes in Elixir - no matter what the two need to agree on the fallback strategy. Today, the database query expects a translation to be available.

The primary question then is: should the default be returned when a locale is configured but a translation is not available.

What makes the most sense to you?

@tozz
Copy link
Author

tozz commented Aug 10, 2024

Regarding the user population I think it's a missed opportunity for them, I love the lib and the Elixir CLDR ecosystem as a whole, makes life a lot easier, so thank you for all the effort :)

I feel like the consistent way would be preferred, so a change from today so that the default is returned when a locale is configured but a translation is not available. That would align it with how the fallback chain and "get by field" works.

@kipcole9
Copy link
Contributor

Makes sense to me, and thank you for the kind words. I'll tackle this ASAP but since I'm on the road it might take a few days.

@kipcole9
Copy link
Contributor

I've push a commit that fixes this issue I believe, would you consider giving this a spin using the main branch? If you're ok, I'll add some additional tests and publish an update.

@kipcole9 kipcole9 reopened this Aug 11, 2024
@tozz
Copy link
Author

tozz commented Aug 11, 2024

Thanks for the quick turn around, I actually don't see any difference with running this from main, I made sure to wipe deps and _build too, but behavior is the same.

@kipcole9
Copy link
Contributor

@tozz, sorry for wasting your time. I'm a bit perplexed because my testing seems to show the correct results for your example. I'll go back and test more closely to your examples.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants