Run translation substitution in 2 passes
By first substituting variables and then tags after, the translation handling can now support strings with variables inside tags, such as: "people <span>reacted with %(foo)s</span>"
This commit is contained in:
parent
c48ecb66d9
commit
32c68feae2
1 changed files with 7 additions and 2 deletions
|
@ -125,20 +125,25 @@ export function _t(text, variables, tags) {
|
||||||
* @return a React <span> component if any non-strings were used in substitutions, otherwise a string
|
* @return a React <span> component if any non-strings were used in substitutions, otherwise a string
|
||||||
*/
|
*/
|
||||||
export function substitute(text, variables, tags) {
|
export function substitute(text, variables, tags) {
|
||||||
const regexpMapping = {};
|
let result = text;
|
||||||
|
|
||||||
if (variables !== undefined) {
|
if (variables !== undefined) {
|
||||||
|
const regexpMapping = {};
|
||||||
for (const variable in variables) {
|
for (const variable in variables) {
|
||||||
regexpMapping[`%\\(${variable}\\)s`] = variables[variable];
|
regexpMapping[`%\\(${variable}\\)s`] = variables[variable];
|
||||||
}
|
}
|
||||||
|
result = replaceByRegexes(result, regexpMapping);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tags !== undefined) {
|
if (tags !== undefined) {
|
||||||
|
const regexpMapping = {};
|
||||||
for (const tag in tags) {
|
for (const tag in tags) {
|
||||||
regexpMapping[`(<${tag}>(.*?)<\\/${tag}>|<${tag}>|<${tag}\\s*\\/>)`] = tags[tag];
|
regexpMapping[`(<${tag}>(.*?)<\\/${tag}>|<${tag}>|<${tag}\\s*\\/>)`] = tags[tag];
|
||||||
}
|
}
|
||||||
|
result = replaceByRegexes(result, regexpMapping);
|
||||||
}
|
}
|
||||||
return replaceByRegexes(text, regexpMapping);
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in a new issue