From eb07e8bc9eb06e6493e019f149b4b17b4c72714b Mon Sep 17 00:00:00 2001 From: Ahmad Salameh Date: Sat, 7 Dec 2024 20:07:29 +0300 Subject: [PATCH 1/2] Fix: warning each child should have a unique key --- src/TransWithoutContext.js | 76 +++++++++++++++++++++++++++----------- 1 file changed, 55 insertions(+), 21 deletions(-) diff --git a/src/TransWithoutContext.js b/src/TransWithoutContext.js index 7da27d126..1c012df05 100644 --- a/src/TransWithoutContext.js +++ b/src/TransWithoutContext.js @@ -298,6 +298,59 @@ const renderNodes = (children, targetString, i18n, i18nOptions, combinedTOpts, s return getChildren(result[0]); }; +const fixComponentProps = (component, index, translation) => { + const componentKey = component.key || index; + const comp = cloneElement(component, { key: componentKey }); + if ( + !comp.props || + !comp.props.children || + (translation.indexOf(`${index}/>`) < 0 && translation.indexOf(`${index} />`) < 0) + ) { + return comp; + } + + function Componentized() { + // <>{comp} + return createElement(Fragment, null, comp); + } + // + return createElement(Componentized); +}; + +const generateArrayComponents = (components, translation) => + components.map((c, index) => fixComponentProps(c, index, translation)); + +const generateObjectComponents = (components, translation) => { + const componentMap = {}; + + Object.keys(components).forEach((c) => { + Object.assign(componentMap, { + [c]: fixComponentProps(components[c], c, translation), + }); + }); + + return componentMap; +}; + +const generateComponents = (components, translation) => { + if (!components) return null; + + // components could be either an array or an object + + if (Array.isArray(components)) { + return generateArrayComponents(components, translation); + } + + if (isObject(components)) { + return generateObjectComponents(components, translation); + } + + // if components is not an array or an object, warn the user + // and return null + console.warn(' component prop expects an object or an array'); + return null; +}; + export function Trans({ children, count, @@ -360,29 +413,10 @@ export function Trans({ }; const translation = key ? t(key, combinedTOpts) : defaultValue; - if (components) { - Object.keys(components).forEach((c) => { - const componentKey = components[c].key || c; - const comp = cloneElement(components[c], { key: componentKey }); - if ( - !comp.props || - !comp.props.children || - (translation.indexOf(`${c}/>`) < 0 && translation.indexOf(`${c} />`) < 0) - ) - return; - - // eslint-disable-next-line react/no-unstable-nested-components - function Componentized() { - // <>{comp} - return createElement(Fragment, null, comp); - } - // - components[c] = createElement(Componentized); - }); - } + const generatedComponents = generateComponents(components, translation); const content = renderNodes( - components || children, + generatedComponents || children, translation, i18n, reactI18nextOptions, From 815ff0ffa578c8bbf528bc070f84e6272c8909af Mon Sep 17 00:00:00 2001 From: Ahmad Salameh Date: Sun, 8 Dec 2024 16:40:54 +0300 Subject: [PATCH 2/2] Requested changes: use warnOnce instead of console.warn --- src/TransWithoutContext.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/TransWithoutContext.js b/src/TransWithoutContext.js index 1c012df05..270d92c24 100644 --- a/src/TransWithoutContext.js +++ b/src/TransWithoutContext.js @@ -347,7 +347,7 @@ const generateComponents = (components, translation) => { // if components is not an array or an object, warn the user // and return null - console.warn(' component prop expects an object or an array'); + warnOnce(' component prop expects an object or an array'); return null; };