Skip to content

Commit

Permalink
fix: plural pseudolocalization with offset (#887)
Browse files Browse the repository at this point in the history
  • Loading branch information
MartinCerny-awin authored Nov 26, 2020
1 parent 672fb1f commit 3d54b4d
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 21 deletions.
63 changes: 44 additions & 19 deletions packages/cli/src/api/pseudoLocalize.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,30 +20,55 @@ describe("PseudoLocalization", () => {
)
})

it("should pseudlocalize plurals with HTML tags", () => {
expect(
pseudoLocalize(
"{messagesCount, plural, zero {There's # <span>message</span>} other {There're # messages}"
describe("Plurals", () => {
it("with value", () => {
expect(
pseudoLocalize("{value, plural, one {# book} other {# books}}")
).toEqual("{value, plural, one {# ƀōōķ} other {# ƀōōķś}}")
})

it("with variable placeholder", () => {
expect(
pseudoLocalize(
"{count, plural, one {{countString} book} other {{countString} books}}"
)
).toEqual(
"{count, plural, one {{countString} ƀōōķ} other {{countString} ƀōōķś}}"
)
).toEqual(
"{messagesCount, plural, zero {Ţĥēŕē'ś # <span>mēśśàĝē</span>} other {Ţĥēŕē'ŕē # mēśśàĝēś}"
)
})
})

it("should pseudolocalize plurals", () => {
expect(
pseudoLocalize("{value, plural, one {# book} other {# books}}")
).toEqual("{value, plural, one {# ƀōōķ} other {# ƀōōķś}}")
expect(
pseudoLocalize(
"{count, plural, one {{countString} book} other {{countString} books}}"
it("with offset", () => {
expect(
pseudoLocalize(
"{count, plural, offset:1 zero {There're no messages} other {There're # messages in your inbox}}"
)
).toEqual(
"{count, plural, offset:1 zero {Ţĥēŕē'ŕē ńō mēśśàĝēś} other {Ţĥēŕē'ŕē # mēśśàĝēś ĩń ŷōũŕ ĩńƀōx}}"
)
).toEqual(
"{count, plural, one {{countString} ƀōōķ} other {{countString} ƀōōķś}}"
)
})

it("with HTML tags", () => {
expect(
pseudoLocalize(
"{count, plural, zero {There's # <span>message</span>} other {There're # messages}"
)
).toEqual(
"{count, plural, zero {Ţĥēŕē'ś # <span>mēśśàĝē</span>} other {Ţĥēŕē'ŕē # mēśśàĝēś}"
)
})

it("with exact number", () => {
expect(
pseudoLocalize(
"{count, plural, =0 {There's # <span>message</span>} other {There're # messages}"
)
).toEqual(
"{count, plural, =0 {Ţĥēŕē'ś # <span>mēśśàĝē</span>} other {Ţĥēŕē'ŕē # mēśśàĝēś}"
)
})
})

it("shouldn't pseudolocalize variables", () => {
it("should not pseudolocalize variables", () => {
expect(pseudoLocalize("replace {count}")).toEqual("ŕēƥĺàćē {count}")
expect(pseudoLocalize("replace { count }")).toEqual("ŕēƥĺàćē { count }")
})
Expand Down
4 changes: 2 additions & 2 deletions packages/cli/src/api/pseudoLocalize.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,9 @@ Example: https://regex101.com/r/bDHD9z/3
const HTMLRegex = /<\/?\w+((\s+\w+(\s*=\s*(?:".*?"|'.*?'|[^'">\s]+))?)+\s*|\s*)\/?>/g
/*
Regex should match js-lingui plurals
Example: https://regex101.com/r/utnbQw/1
Example: https://regex101.com/r/utnbQw/3
*/
const PluralRegex = /{\w*,\s*plural,\s*\w*\s*{|}\s*(zero|one|two|few|many|other)\s*({|})/g
const PluralRegex = /({\w*,\s*plural,(.|\n)*?{)|(}\s*(offset|zero|one|two|few|many|other)\s*{)/g
/*
Regex should match js-lingui variables
Example: https://regex101.com/r/dw1QHb/2
Expand Down

1 comment on commit 3d54b4d

@vercel
Copy link

@vercel vercel bot commented on 3d54b4d Nov 26, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.