From 5c8d2014edc87e7a440d87e8a1ef384e825f2317 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Mon, 9 Dec 2024 17:17:43 +0100 Subject: [PATCH] Disable units when mixed units are used --- packages/components/src/box-control/input-control.tsx | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/packages/components/src/box-control/input-control.tsx b/packages/components/src/box-control/input-control.tsx index 6678cf1fdbd31d..9086cebedc2749 100644 --- a/packages/components/src/box-control/input-control.tsx +++ b/packages/components/src/box-control/input-control.tsx @@ -131,7 +131,6 @@ export default function BoxInputControl( { hasValues && defaultValuesToModify.length > 1 && isValueMixed( values, defaultValuesToModify ); - const mixedPlaceholder = isMixed ? __( 'Mixed' ) : undefined; const [ parsedQuantity, parsedUnit ] = parseQuantityAndUnitFromRawValue( mergedValue ); const computedUnit = hasValues @@ -139,8 +138,15 @@ export default function BoxInputControl( { : selectedUnits[ defaultValuesToModify[ 0 ] ]; const generatedId = useInstanceId( BoxInputControl, 'box-control-input' ); const inputId = [ generatedId, side ].join( '-' ); + const isMixedUnit = + defaultValuesToModify.length > 1 && + mergedValue === undefined && + defaultValuesToModify.some( + ( s ) => selectedUnits[ s ] !== computedUnit + ); const usedValue = mergedValue === undefined && computedUnit ? computedUnit : mergedValue; + const mixedPlaceholder = isMixed || isMixedUnit ? __( 'Mixed' ) : undefined; return ( @@ -153,6 +159,7 @@ export default function BoxInputControl( { className="component-box-control__unit-control" id={ inputId } isPressEnterToChange + disableUnits={ isMixed || isMixedUnit } value={ usedValue } onChange={ handleOnValueChange } onUnitChange={ handleOnUnitChange }