HTML tags in plaintext digest when missing a translation

Hi,

I subscribed to digests on Discourse instances and read my emails in plaintext. Huge :+1: for having a really usable and readable plaintext version!

However, I recently discovered that some HTML tags were present in the digests when server lacks some translations. For instance, consider the unsubscribe link from the digest, translation is here, but is not available in the French locale.

Resulting email has following content in plaintext:

<span class="translation_missing" title="translation missing: fr.user_notifications.digest.unsubscribe">Unsubscribe</span>

with the unsubscribe link reference below. I would have expected it to be something like

Unsubscribe [3]

(where [3] is the reference of the unsubscribe link at the bottom of the email body).

Thanks!

1 « J'aime »

Not really a bug, its simply a missing french translation see: Contribute a translation to Discourse

I’d disagree with the fact that it is not a bug. The root of the issue, is that there is a missing French translation, which I totally agree with.

But the issue I am reporting extend beyond the missing French translation. The true issue (in my opinion) is that if a translation is missing, plaintext emails get HTML tags in them. The span should be replaced by its content, in the plaintext version, in the case of a missing translation.

Hmm, yeah … that is somewhat odd, we usually fallback to english but not here.

1 « J'aime »

The fallback to English is happening, but still the span is there.

<span class="translation_missing" title="translation missing: en.user_notifications.digest.unsubscribe">Unsubscribe</span>

Notice the word “Unsubscribe” is there. My site was supposed to be French, but it’s saying that the english translation is missing too… So wrong.

ActiveSupport is trying to be helpful by adding that span, and I don’t see a way to stop it in the case that we’re not using it in HTML…

4 « J'aime »

Le chemin suivi par les notifications e-mail a changé l’année dernière, ce qui a peut-être résolu ce problème ? J’ai supprimé certaines traductions françaises et je constate que la version texte du résumé utilise l’anglais là où les chaînes françaises manquent, et il n’y a aucune balise HTML.

Ce résumé est envoyé depuis [Localhost][1] lorsque nous ne vous avons pas vu depuis un certain temps. Modifiez [vos préférences de courriel][7] ou [cliquez ici][8] pour vous désabonner.

3 « J'aime »