feat(compiler): add "original" placeholder value on extracted XMB (#25079)
Update XMB placeholders(<ph>) to include the original value on top of an example. Placeholders can by definition have one example(<ex>) tag and a text node. The text node is used by TC as the "original" value from the placeholder, while the example should represent a dummy value. For example: <ph name="PET"><ex>Gopher</ex>{{ petName }}</ph>. This change makes sure that we have the original text, but it *DOES NOT* make sure that the example is correct. The example has the same wrong behavior of showing the interpolation text rather than a useful example. No breaking changes, but tools that depend on the previous behavior and don't consider the full XMB definition may fail to parse the XMB. Fixes b/72565847 PR Close #25079
This commit is contained in:

committed by
Igor Minar

parent
24789e9ad9
commit
e99d860393
@ -43,6 +43,7 @@ jasmine_node_test(
|
||||
],
|
||||
deps = [
|
||||
":extract_i18n_lib",
|
||||
"//packages/common:npm_package",
|
||||
"//packages/core",
|
||||
"//tools/testing:node",
|
||||
],
|
||||
|
@ -46,6 +46,15 @@ const EXPECTED_XMB = `<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<msg id="8136548302122759730" desc="desc" meaning="meaning"><source>src/basic.html:1</source><source>src/comp2.ts:1</source><source>src/basic.html:1</source>translate me</msg>
|
||||
<msg id="9038505069473852515"><source>src/basic.html:3,4</source><source>src/comp2.ts:3,4</source><source>src/comp2.ts:2,3</source><source>src/basic.html:3,4</source>
|
||||
Welcome</msg>
|
||||
<msg id="5611534349548281834" desc="with ICU"><source>src/icu.html:1,3</source><source>src/icu.html:5</source>{VAR_PLURAL, plural, =1 {book} other {books} }</msg>
|
||||
<msg id="5811701742971715242" desc="with ICU and other things"><source>src/icu.html:4,6</source>
|
||||
foo <ph name="ICU"><ex>{ count, plural, =1 {...} other {...}}</ex>{ count, plural, =1 {...} other {...}}</ph>
|
||||
</msg>
|
||||
<msg id="7254052530614200029" desc="with placeholders"><source>src/placeholders.html:1</source>Name: <ph name="START_BOLD_TEXT"><ex><b></ex><b></ph><ph name="NAME"><ex>{{
|
||||
name // i18n(ph="name")
|
||||
}}</ex>{{
|
||||
name // i18n(ph="name")
|
||||
}}</ph><ph name="CLOSE_BOLD_TEXT"><ex></b></ex></b></ph></msg>
|
||||
</messagebundle>
|
||||
`;
|
||||
|
||||
@ -90,6 +99,41 @@ const EXPECTED_XLIFF = `<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<context context-type="linenumber">3</context>
|
||||
</context-group>
|
||||
</trans-unit>
|
||||
<trans-unit id="83937c05b1216e7f4c02a85454260e28fd72d1e3" datatype="html">
|
||||
<source>{VAR_PLURAL, plural, =1 {book} other {books} }</source>
|
||||
<context-group purpose="location">
|
||||
<context context-type="sourcefile">src/icu.html</context>
|
||||
<context context-type="linenumber">1</context>
|
||||
</context-group>
|
||||
<note priority="1" from="description">with ICU</note>
|
||||
</trans-unit>
|
||||
<trans-unit id="540c5f481129419ef21017f396b6c2d0869ca4d2" datatype="html">
|
||||
<source>
|
||||
foo <x id="ICU" equiv-text="{ count, plural, =1 {...} other {...}}"/>
|
||||
</source>
|
||||
<context-group purpose="location">
|
||||
<context context-type="sourcefile">src/icu.html</context>
|
||||
<context context-type="linenumber">4</context>
|
||||
</context-group>
|
||||
<note priority="1" from="description">with ICU and other things</note>
|
||||
</trans-unit>
|
||||
<trans-unit id="ca7678090fddd04441d63b1218177af65f23342d" datatype="html">
|
||||
<source>{VAR_PLURAL, plural, =1 {book} other {books} }</source>
|
||||
<context-group purpose="location">
|
||||
<context context-type="sourcefile">src/icu.html</context>
|
||||
<context context-type="linenumber">5</context>
|
||||
</context-group>
|
||||
</trans-unit>
|
||||
<trans-unit id="9311399c1ca7c75f771d77acb129e50581c6ec1f" datatype="html">
|
||||
<source>Name: <x id="START_BOLD_TEXT" ctype="x-b" equiv-text="<b>"/><x id="NAME" equiv-text="{{
|
||||
name // i18n(ph="name")
|
||||
}}"/><x id="CLOSE_BOLD_TEXT" ctype="x-b" equiv-text="</b>"/></source>
|
||||
<context-group purpose="location">
|
||||
<context context-type="sourcefile">src/placeholders.html</context>
|
||||
<context context-type="linenumber">1</context>
|
||||
</context-group>
|
||||
<note priority="1" from="description">with placeholders</note>
|
||||
</trans-unit>
|
||||
</body>
|
||||
</file>
|
||||
</xliff>
|
||||
@ -122,6 +166,38 @@ const EXPECTED_XLIFF2 = `<?xml version="1.0" encoding="UTF-8" ?>
|
||||
Welcome</source>
|
||||
</segment>
|
||||
</unit>
|
||||
<unit id="5611534349548281834">
|
||||
<notes>
|
||||
<note category="description">with ICU</note>
|
||||
<note category="location">src/icu.html:1,3</note>
|
||||
<note category="location">src/icu.html:5</note>
|
||||
</notes>
|
||||
<segment>
|
||||
<source>{VAR_PLURAL, plural, =1 {book} other {books} }</source>
|
||||
</segment>
|
||||
</unit>
|
||||
<unit id="5811701742971715242">
|
||||
<notes>
|
||||
<note category="description">with ICU and other things</note>
|
||||
<note category="location">src/icu.html:4,6</note>
|
||||
</notes>
|
||||
<segment>
|
||||
<source>
|
||||
foo <ph id="0" equiv="ICU" disp="{ count, plural, =1 {...} other {...}}"/>
|
||||
</source>
|
||||
</segment>
|
||||
</unit>
|
||||
<unit id="7254052530614200029">
|
||||
<notes>
|
||||
<note category="description">with placeholders</note>
|
||||
<note category="location">src/placeholders.html:1</note>
|
||||
</notes>
|
||||
<segment>
|
||||
<source>Name: <pc id="0" equivStart="START_BOLD_TEXT" equivEnd="CLOSE_BOLD_TEXT" type="fmt" dispStart="<b>" dispEnd="</b>"><ph id="1" equiv="NAME" disp="{{
|
||||
name // i18n(ph="name")
|
||||
}}"/></pc></source>
|
||||
</segment>
|
||||
</unit>
|
||||
</file>
|
||||
</xliff>
|
||||
`;
|
||||
@ -132,7 +208,7 @@ describe('extract_i18n command line', () => {
|
||||
let write: (fileName: string, content: string) => void;
|
||||
let errorSpy: jasmine.Spy&((s: string) => void);
|
||||
|
||||
function writeConfig(tsconfig: string = '{"extends": "./tsconfig-base.json"}') {
|
||||
function writeConfig(tsconfig = '{"extends": "./tsconfig-base.json"}') {
|
||||
write('tsconfig.json', tsconfig);
|
||||
}
|
||||
|
||||
@ -147,7 +223,7 @@ describe('extract_i18n command line', () => {
|
||||
basePath = makeTempDir();
|
||||
write = (fileName: string, content: string) => {
|
||||
const dir = path.dirname(fileName);
|
||||
if (dir != '.') {
|
||||
if (dir !== '.') {
|
||||
const newDir = path.join(basePath, dir);
|
||||
if (!fs.existsSync(newDir)) fs.mkdirSync(newDir);
|
||||
}
|
||||
@ -223,14 +299,54 @@ describe('extract_i18n command line', () => {
|
||||
})
|
||||
export class BasicCmp3 {}`);
|
||||
|
||||
write('src/placeholders.html', `<div i18n="with placeholders">Name: <b>{{
|
||||
name // i18n(ph="name")
|
||||
}}</b></div>`);
|
||||
|
||||
write('src/placeholder_cmp.ts', `
|
||||
import {Component} from '@angular/core';
|
||||
|
||||
@Component({
|
||||
selector: 'placeholders',
|
||||
templateUrl: './placeholders.html',
|
||||
})
|
||||
export class PlaceholderCmp { name = 'whatever'; }`);
|
||||
|
||||
write('src/icu.html', `<div i18n="with ICU">{
|
||||
count, plural, =1 {book} other {books}
|
||||
}</div>
|
||||
<div i18n="with ICU and other things">
|
||||
foo { count, plural, =1 {book} other {books} }
|
||||
</div>`);
|
||||
|
||||
write('src/icu_cmp.ts', `
|
||||
import {Component} from '@angular/core';
|
||||
|
||||
@Component({
|
||||
selector: 'icu',
|
||||
templateUrl: './icu.html',
|
||||
})
|
||||
export class IcuCmp { count = 3; }`);
|
||||
|
||||
write('src/module.ts', `
|
||||
import {NgModule} from '@angular/core';
|
||||
import {CommonModule} from '@angular/common';
|
||||
import {BasicCmp1} from './comp1';
|
||||
import {BasicCmp2, BasicCmp4} from './comp2';
|
||||
import {BasicCmp3} from './comp3';
|
||||
import {PlaceholderCmp} from './placeholder_cmp';
|
||||
import {IcuCmp} from './icu_cmp';
|
||||
|
||||
@NgModule({
|
||||
declarations: [BasicCmp1, BasicCmp2, BasicCmp3, BasicCmp4]
|
||||
declarations: [
|
||||
BasicCmp1,
|
||||
BasicCmp2,
|
||||
BasicCmp3,
|
||||
BasicCmp4,
|
||||
PlaceholderCmp,
|
||||
IcuCmp,
|
||||
],
|
||||
imports: [CommonModule],
|
||||
})
|
||||
export class I18nModule {}
|
||||
`);
|
||||
|
Reference in New Issue
Block a user