mapcomplete/Models/ThemeConfig/Conversion/AddContextToTranslations.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

158 lines
4.5 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { DesugaringStep } from "./Conversion"
import { Utils } from "../../../Utils"
import Translations from "../../../UI/i18n/Translations"
export class AddContextToTranslations<T> extends DesugaringStep<T> {
2022-09-08 21:40:48 +02:00
private readonly _prefix: string
constructor(prefix = "") {
2022-09-08 21:40:48 +02:00
super(
"Adds a '_context' to every object that is probably a translation",
["_context"],
"AddContextToTranslation"
)
this._prefix = prefix
}
/**
* const theme = {
* layers: [
* {
* builtin: ["abc"],
* override: {
* title:{
* en: "Some title"
* }
* }
* }
2022-09-08 21:40:48 +02:00
* ]
* }
* const rewritten = new AddContextToTranslations<any>("prefix:").convert(theme, "context").result
* const expected = {
* layers: [
* {
* builtin: ["abc"],
* override: {
* title:{
* _context: "prefix:context.layers.0.override.title"
* en: "Some title"
* }
* }
* }
2022-09-08 21:40:48 +02:00
* ]
* }
* rewritten // => expected
2022-09-08 21:40:48 +02:00
*
* // should use the ID if one is present instead of the index
* const theme = {
* layers: [
* {
* tagRenderings:[
* {id: "some-tr",
* question:{
* en:"Question?"
* }
* }
* ]
* }
2022-09-08 21:40:48 +02:00
* ]
* }
* const rewritten = new AddContextToTranslations<any>("prefix:").convert(theme, "context").result
* const expected = {
* layers: [
* {
* tagRenderings:[
* {id: "some-tr",
* question:{
* _context: "prefix:context.layers.0.tagRenderings.some-tr.question"
* en:"Question?"
* }
* }
* ]
* }
2022-09-08 21:40:48 +02:00
* ]
* }
* rewritten // => expected
2022-09-08 21:40:48 +02:00
*
* // should preserve nulls
* const theme = {
* layers: [
* {
* builtin: ["abc"],
* override: {
* name:null
* }
* }
2022-09-08 21:40:48 +02:00
* ]
* }
* const rewritten = new AddContextToTranslations<any>("prefix:").convert(theme, "context").result
* const expected = {
* layers: [
* {
* builtin: ["abc"],
* override: {
* name: null
* }
* }
2022-09-08 21:40:48 +02:00
* ]
* }
* rewritten // => expected
2022-09-08 21:40:48 +02:00
*
*
2022-07-11 09:14:26 +02:00
* // Should ignore all if '#dont-translate' is set
* const theme = {
* "#dont-translate": "*",
* layers: [
* {
* builtin: ["abc"],
* override: {
* title:{
* en: "Some title"
* }
* }
* }
2022-09-08 21:40:48 +02:00
* ]
2022-07-11 09:14:26 +02:00
* }
* const rewritten = new AddContextToTranslations<any>("prefix:").convert(theme, "context").result
* rewritten // => theme
2022-09-08 21:40:48 +02:00
*
*/
2022-09-08 21:40:48 +02:00
convert(
json: T,
context: string
): { result: T; errors?: string[]; warnings?: string[]; information?: string[] } {
if (json["#dont-translate"] === "*") {
return { result: json }
2022-07-11 09:14:26 +02:00
}
2022-09-08 21:40:48 +02:00
const result = Utils.WalkJson(
json,
(leaf, path) => {
if (leaf === undefined || leaf === null) {
return leaf
}
if (typeof leaf === "object") {
// follow the path. If we encounter a number, check that there is no ID we can use instead
let breadcrumb = json
for (let i = 0; i < path.length; i++) {
const pointer = path[i]
breadcrumb = breadcrumb[pointer]
if (pointer.match("[0-9]+") && breadcrumb["id"] !== undefined) {
path[i] = breadcrumb["id"]
}
}
2022-09-08 21:40:48 +02:00
return { ...leaf, _context: this._prefix + context + "." + path.join(".") }
} else {
return leaf
}
2022-09-08 21:40:48 +02:00
},
(obj) => obj === undefined || obj === null || Translations.isProbablyATranslation(obj)
)
return {
2022-09-08 21:40:48 +02:00
result,
}
}
2022-09-08 21:40:48 +02:00
}