| 
									
										
										
										
											2023-11-02 04:35:32 +01:00
										 |  |  | import { DesugaringStep } from "./Conversion" | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  | import { Utils } from "../../../Utils" | 
					
						
							|  |  |  | import Translations from "../../../UI/i18n/Translations" | 
					
						
							| 
									
										
										
										
											2023-11-02 04:35:32 +01:00
										 |  |  | import { ConversionContext } from "./ConversionContext" | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export class AddContextToTranslations<T> extends DesugaringStep<T> { | 
					
						
							|  |  |  |     private readonly _prefix: string | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor(prefix = "") { | 
					
						
							|  |  |  |         super( | 
					
						
							| 
									
										
										
										
											2025-05-16 15:48:55 +02:00
										 |  |  |             "AddContextToTranslation", | 
					
						
							| 
									
										
										
										
											2025-06-04 00:21:28 +02:00
										 |  |  |             "Adds a '_context' to every object that is probably a translation" | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |         this._prefix = prefix | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * const theme = { | 
					
						
							|  |  |  |      *   layers: [ | 
					
						
							|  |  |  |      *       { | 
					
						
							|  |  |  |      *           builtin: ["abc"], | 
					
						
							|  |  |  |      *           override: { | 
					
						
							|  |  |  |      *               title:{ | 
					
						
							|  |  |  |      *                   en: "Some title" | 
					
						
							|  |  |  |      *               } | 
					
						
							|  |  |  |      *           } | 
					
						
							|  |  |  |      *       } | 
					
						
							|  |  |  |      *   ] | 
					
						
							|  |  |  |      * } | 
					
						
							| 
									
										
										
										
											2023-10-12 16:55:26 +02:00
										 |  |  |      * const rewritten = new AddContextToTranslations<any>("prefix:").convertStrict(theme, ConversionContext.test()) | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |      * const expected = { | 
					
						
							|  |  |  |      *   layers: [ | 
					
						
							|  |  |  |      *       { | 
					
						
							|  |  |  |      *           builtin: ["abc"], | 
					
						
							|  |  |  |      *           override: { | 
					
						
							|  |  |  |      *               title:{ | 
					
						
							| 
									
										
										
										
											2023-10-12 16:55:26 +02:00
										 |  |  |      *                  _context: "prefix:layers.0.override.title" | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |      *                   en: "Some title" | 
					
						
							|  |  |  |      *               } | 
					
						
							|  |  |  |      *           } | 
					
						
							|  |  |  |      *       } | 
					
						
							|  |  |  |      *   ] | 
					
						
							|  |  |  |      * } | 
					
						
							|  |  |  |      * rewritten // => expected
 | 
					
						
							| 
									
										
										
										
											2022-04-13 00:31:13 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-04-14 19:46:14 +02:00
										 |  |  |      * // should use the ID if one is present instead of the index
 | 
					
						
							|  |  |  |      * const theme = { | 
					
						
							|  |  |  |      *   layers: [ | 
					
						
							|  |  |  |      *       { | 
					
						
							|  |  |  |      *           tagRenderings:[ | 
					
						
							|  |  |  |      *               {id: "some-tr", | 
					
						
							|  |  |  |      *               question:{ | 
					
						
							|  |  |  |      *                   en:"Question?" | 
					
						
							|  |  |  |      *               } | 
					
						
							|  |  |  |      *               } | 
					
						
							|  |  |  |      *           ] | 
					
						
							|  |  |  |      *       } | 
					
						
							|  |  |  |      *   ] | 
					
						
							|  |  |  |      * } | 
					
						
							| 
									
										
										
										
											2023-10-12 16:55:26 +02:00
										 |  |  |      * const rewritten = new AddContextToTranslations<any>("prefix:").convertStrict(theme, ConversionContext.test()) | 
					
						
							| 
									
										
										
										
											2022-04-14 19:46:14 +02:00
										 |  |  |      * const expected = { | 
					
						
							|  |  |  |      *   layers: [ | 
					
						
							|  |  |  |      *       { | 
					
						
							|  |  |  |      *           tagRenderings:[ | 
					
						
							|  |  |  |      *               {id: "some-tr", | 
					
						
							|  |  |  |      *               question:{ | 
					
						
							| 
									
										
										
										
											2023-10-12 16:55:26 +02:00
										 |  |  |      *                  _context: "prefix:layers.0.tagRenderings.some-tr.question" | 
					
						
							| 
									
										
										
										
											2022-04-14 19:46:14 +02:00
										 |  |  |      *                   en:"Question?" | 
					
						
							|  |  |  |      *               } | 
					
						
							|  |  |  |      *               } | 
					
						
							|  |  |  |      *           ] | 
					
						
							|  |  |  |      *       } | 
					
						
							|  |  |  |      *   ] | 
					
						
							|  |  |  |      * } | 
					
						
							|  |  |  |      * rewritten // => expected
 | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-04-13 00:31:13 +02:00
										 |  |  |      * // should preserve nulls
 | 
					
						
							|  |  |  |      * const theme = { | 
					
						
							|  |  |  |      *   layers: [ | 
					
						
							|  |  |  |      *       { | 
					
						
							|  |  |  |      *           builtin: ["abc"], | 
					
						
							|  |  |  |      *           override: { | 
					
						
							|  |  |  |      *               name:null | 
					
						
							|  |  |  |      *           } | 
					
						
							|  |  |  |      *       } | 
					
						
							|  |  |  |      *   ] | 
					
						
							|  |  |  |      * } | 
					
						
							| 
									
										
										
										
											2023-10-12 16:55:26 +02:00
										 |  |  |      * const rewritten = new AddContextToTranslations<any>("prefix:").convertStrict(theme, ConversionContext.test()) | 
					
						
							| 
									
										
										
										
											2022-04-13 00:31:13 +02:00
										 |  |  |      * const expected = { | 
					
						
							|  |  |  |      *   layers: [ | 
					
						
							|  |  |  |      *       { | 
					
						
							|  |  |  |      *           builtin: ["abc"], | 
					
						
							|  |  |  |      *           override: { | 
					
						
							|  |  |  |      *               name: null | 
					
						
							|  |  |  |      *           } | 
					
						
							|  |  |  |      *       } | 
					
						
							|  |  |  |      *   ] | 
					
						
							|  |  |  |      * } | 
					
						
							|  |  |  |      * rewritten // => expected
 | 
					
						
							| 
									
										
										
										
											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" | 
					
						
							|  |  |  |      *               } | 
					
						
							|  |  |  |      *           } | 
					
						
							|  |  |  |      *       } | 
					
						
							|  |  |  |      *   ] | 
					
						
							|  |  |  |      * } | 
					
						
							| 
									
										
										
										
											2023-10-12 16:55:26 +02:00
										 |  |  |      * const rewritten = new AddContextToTranslations<any>("prefix:").convertStrict(theme, ConversionContext.test()) | 
					
						
							| 
									
										
										
										
											2022-07-11 09:14:26 +02:00
										 |  |  |      * rewritten // => theme
 | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2023-10-11 04:16:52 +02:00
										 |  |  |     convert(json: T, context: ConversionContext): T { | 
					
						
							| 
									
										
										
										
											2022-07-11 09:14:26 +02:00
										 |  |  |         if (json["#dont-translate"] === "*") { | 
					
						
							| 
									
										
										
										
											2023-10-11 04:16:52 +02:00
										 |  |  |             return json | 
					
						
							| 
									
										
										
										
											2022-07-11 09:14:26 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 04:16:52 +02:00
										 |  |  |         return Utils.WalkJson( | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |             json, | 
					
						
							|  |  |  |             (leaf, path) => { | 
					
						
							| 
									
										
										
										
											2022-04-13 00:31:13 +02:00
										 |  |  |                 if (leaf === undefined || leaf === null) { | 
					
						
							|  |  |  |                     return leaf | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |                 if (typeof leaf === "object") { | 
					
						
							| 
									
										
										
										
											2022-04-14 19:46:14 +02:00
										 |  |  |                     // 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
										 |  |  |                         } | 
					
						
							| 
									
										
										
										
											2022-04-14 19:46:14 +02:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-12 16:55:26 +02:00
										 |  |  |                     return { | 
					
						
							|  |  |  |                         ...leaf, | 
					
						
							|  |  |  |                         _context: this._prefix + context.path.concat(path).join("."), | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |                     return leaf | 
					
						
							| 
									
										
										
										
											2022-04-14 19:46:14 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-04-13 00:31:13 +02:00
										 |  |  |             }, | 
					
						
							|  |  |  |             (obj) => obj === undefined || obj === null || Translations.isProbablyATranslation(obj) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-04-08 21:53:08 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } |