UNPKG

@intlayer/core

Version:

Includes core Intlayer functions like translation, dictionary, and utility functions shared across multiple packages.

60 lines (58 loc) 2.66 kB
import { NodeType } from "@intlayer/types"; //#region src/dictionaryManipulator/editDictionaryByKeyPath.ts const editDictionaryByKeyPath = (dictionaryContent, keyPath, newValue) => { let currentValue = dictionaryContent; let parentValue = null; let lastKeys = []; if (keyPath.length === 0) return newValue; try { for (let i = 0; i < keyPath.length; i++) { const keyObj = keyPath[i]; parentValue = currentValue; if (keyObj.type === NodeType.Object || keyObj.type === NodeType.Array) { lastKeys = [keyObj.key]; if (!currentValue[keyObj.key] || typeof currentValue[keyObj.key] !== "object") currentValue[keyObj.key] = {}; currentValue = currentValue[keyObj.key]; } if (keyObj.type === NodeType.Translation || keyObj.type === NodeType.Enumeration) { lastKeys = [keyObj.type, keyObj.key]; if (!currentValue[keyObj.type] || typeof currentValue[keyObj.type] !== "object") currentValue[keyObj.type] = {}; if (!currentValue[keyObj.type][keyObj.key] || typeof currentValue[keyObj.type][keyObj.key] !== "object") currentValue[keyObj.type][keyObj.key] = {}; currentValue = currentValue[keyObj.type][keyObj.key]; } if (keyObj.type === NodeType.Enumeration || keyObj.type === NodeType.Condition) { lastKeys = [keyObj.type, keyObj.key]; if (!currentValue[keyObj.type] || typeof currentValue[keyObj.type] !== "object") currentValue[keyObj.type] = {}; if (!currentValue[keyObj.type][keyObj.key] || typeof currentValue[keyObj.type][keyObj.key] !== "object") currentValue[keyObj.type][keyObj.key] = {}; currentValue = currentValue[keyObj.type][keyObj.key]; } if (keyObj.type === NodeType.Markdown || keyObj.type === NodeType.Insertion) { lastKeys = [keyObj.type]; if (!currentValue[keyObj.type] || typeof currentValue[keyObj.type] !== "object") currentValue[keyObj.type] = ""; currentValue = currentValue[keyObj.type]; } if (keyObj.type === NodeType.File) { lastKeys = ["content"]; currentValue = currentValue.content; } if (keyObj.type) {} if (i === keyPath.length - 1 && parentValue && lastKeys.length > 0) { let target = parentValue; for (const key of lastKeys.slice(0, -1)) target = target[key]; if (typeof newValue === "undefined") delete target[lastKeys[lastKeys.length - 1]]; else target[lastKeys[lastKeys.length - 1]] = newValue; } } return dictionaryContent; } catch (error) { console.error("Cannot edit dictionary by key path", { dictionaryContent, keyPath, newValue }, error); return dictionaryContent; } }; //#endregion export { editDictionaryByKeyPath }; //# sourceMappingURL=editDictionaryByKeyPath.mjs.map