Skip to content

Commit

Permalink
fix: ensure repeatRenderManager passes down props correctly
Browse files Browse the repository at this point in the history
Related to #1029
  • Loading branch information
Skaiir authored and vsgoulart committed Feb 20, 2024
1 parent be51c3a commit 352a893
Showing 1 changed file with 72 additions and 30 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -79,36 +79,19 @@ export class RepeatRenderManager {

return (
<>
{displayValues.map((value, index) => {
const elementProps = useMemo(() => ({
...restProps,
indexes: { ...(indexes || {}), [ repeaterField.id ]: index }
}), [ index ]);

const localExpressionContextInfo = useMemo(() => ({
data: parentExpressionContextInfo.data,
this: value,
parent: buildExpressionContext(parentExpressionContextInfo),
i: [ ...parentExpressionContextInfo.i , index + 1 ]
}), [ index, value ]);

return !showRemove ?
<LocalExpressionContext.Provider value={ localExpressionContextInfo }>
<RowsRenderer { ...elementProps } />
</LocalExpressionContext.Provider> :
<div class="fjs-repeat-row-container">
<div class="fjs-repeat-row-rows">
<LocalExpressionContext.Provider value={ localExpressionContextInfo }>
<RowsRenderer { ...elementProps } />
</LocalExpressionContext.Provider>
</div>
<button class="fjs-repeat-row-remove" type="button" aria-label={ `Remove list item ${index + 1}` } onClick={ () => onDeleteItem(index) }>
<div class="fjs-repeat-row-remove-icon-container">
<DeleteSvg />
</div>
</button>
</div>;
})}
{displayValues.map((value, index) =>
<RepetitionScaffold
key={ index }
index={ index }
value={ value }
parentExpressionContextInfo={ parentExpressionContextInfo }
repeaterField={ repeaterField }
RowsRenderer={ RowsRenderer }
indexes={ indexes }
onDeleteItem={ onDeleteItem }
showRemove={ showRemove }
{ ...restProps } />
)}
</>
);
}
Expand Down Expand Up @@ -196,4 +179,63 @@ export class RepeatRenderManager {

}

/**
* Individual repetition of a repeated field and context scaffolding.
*
* @param {Object} props
* @param {number} props.index
* @param {Object} props.value
* @param {Object} props.parentExpressionContextInfo
* @param {Object} props.repeaterField
* @param {Function} props.RowsRenderer
* @param {Object} props.indexes
* @param {Function} props.onDeleteItem
* @param {boolean} props.showRemove
*/

const RepetitionScaffold = (props) => {

const {
index,
value,
parentExpressionContextInfo,
repeaterField,
RowsRenderer,
indexes,
onDeleteItem,
showRemove,
...restProps
} = props;

const elementProps = useMemo(() => ({
...restProps,
indexes: { ...(indexes || {}), [ repeaterField.id ]: index }
}), [ index, indexes, repeaterField.id, restProps ]);

const localExpressionContextInfo = useMemo(() => ({
data: parentExpressionContextInfo.data,
this: value,
parent: buildExpressionContext(parentExpressionContextInfo),
i: [ ...parentExpressionContextInfo.i , index + 1 ]
}), [ index, parentExpressionContextInfo, value ]);

return !showRemove ?
<LocalExpressionContext.Provider value={ localExpressionContextInfo }>
<RowsRenderer { ...elementProps } />
</LocalExpressionContext.Provider> :
<div class="fjs-repeat-row-container">
<div class="fjs-repeat-row-rows">
<LocalExpressionContext.Provider value={ localExpressionContextInfo }>
<RowsRenderer { ...elementProps } />
</LocalExpressionContext.Provider>
</div>
<button class="fjs-repeat-row-remove" type="button" aria-label={ `Remove list item ${index + 1}` } onClick={ () => onDeleteItem(index) }>
<div class="fjs-repeat-row-remove-icon-container">
<DeleteSvg />
</div>
</button>
</div>;

};

RepeatRenderManager.$inject = [ 'form', 'formFields', 'formFieldRegistry', 'pathRegistry' ];

0 comments on commit 352a893

Please sign in to comment.