Skip to content

Commit

Permalink
Allow negative values for margin controls (#60347)
Browse files Browse the repository at this point in the history
* allow negative margins on margin controls

* change z-index when block is selected in the editor

* reduced exagerated z-index

* Add "has-child-selected".

* added position relative to groups with backgrounds

* target only group blocks

* added period to comment

* avoid dragging input to negative values

* fix min values for non margin inputs

* change min value on box control component too

* disable slider when value is out of bounds

* Revert "disable slider when value is out of bounds"

This reverts commit 194e413.

* disable dragging to the negatives on BoxControl

* updated changelog

* only apply z-index if negative margins are present

* move the changelog entry to unreleased

---------

Co-authored-by: jasmussen <joen@automattic.com>
Co-authored-by: Ben Dwyer <ben@scruffian.com>
Unlinked contributors: timsinc, jonathanelmgren, diegosomar, nendeb, bnjunge, dimasoho, dmpinder, wpalani, Pacicio, adamghorne, thomasnuggets, wiinf, alexisreau, madfcat, curiousduck-dev, alperta, wpsoul, DevAndreyBilchenko.

Co-authored-by: MaggieCabrera <onemaggie@git.wordpress.org>
Co-authored-by: jasmussen <joen@git.wordpress.org>
Co-authored-by: scruffian <scruffian@git.wordpress.org>
Co-authored-by: aaronrobertshaw <aaronrobertshaw@git.wordpress.org>
Co-authored-by: draganescu <andraganescu@git.wordpress.org>
Co-authored-by: mirka <0mirka00@git.wordpress.org>
Co-authored-by: markhowellsmead <markhowellsmead@git.wordpress.org>
Co-authored-by: andrewserong <andrewserong@git.wordpress.org>
Co-authored-by: bgardner <bgardner@git.wordpress.org>
Co-authored-by: annezazu <annezazu@git.wordpress.org>
Co-authored-by: colorful-tones <colorful-tones@git.wordpress.org>
Co-authored-by: carolinan <poena@git.wordpress.org>
Co-authored-by: afercia <afercia@git.wordpress.org>
Co-authored-by: richtabor <richtabor@git.wordpress.org>
Co-authored-by: thirumani02 <thirumani02@git.wordpress.org>
Co-authored-by: aurooba <aurooba@git.wordpress.org>
Co-authored-by: mrfoxtalbot <mrfoxtalbot@git.wordpress.org>
Co-authored-by: daviedR <daviedr@git.wordpress.org>
Co-authored-by: samxmunoz <samanthaxmunoz@git.wordpress.org>
Co-authored-by: rolf-yoast <rolfsiebers@git.wordpress.org>
Co-authored-by: aristath <aristath@git.wordpress.org>
Co-authored-by: AdsonCicilioti <adson-cicilioti@git.wordpress.org>
Co-authored-by: peiche <peiche@git.wordpress.org>
Co-authored-by: namithj <namithjawahar@git.wordpress.org>
Co-authored-by: rxnlabs <rxnlabs@git.wordpress.org>
Co-authored-by: seothemes <blockify@git.wordpress.org>
Co-authored-by: nicmare <nicmare@git.wordpress.org>
Co-authored-by: hagege <hage@git.wordpress.org>
Co-authored-by: flipflap <webgarten@git.wordpress.org>
Co-authored-by: websitegenii <websitegenii@git.wordpress.org>
Co-authored-by: jameskoster <jameskoster@git.wordpress.org>
Co-authored-by: dkjensen <dkjensen@git.wordpress.org>
Co-authored-by: cawa-93 <cawa-93@git.wordpress.org>
Co-authored-by: asmittle <alisongodar@git.wordpress.org>
Co-authored-by: QuietNoise <quietnoise@git.wordpress.org>
Co-authored-by: itsjustdj <itsjustdj@git.wordpress.org>
Co-authored-by: metabreakr <jaruzek@git.wordpress.org>
Co-authored-by: ohiawins <ohia@git.wordpress.org>
Co-authored-by: JiveDig <jivedig@git.wordpress.org>
Co-authored-by: ouw-jvt <jtolleouw@git.wordpress.org>
Co-authored-by: flabernardez <flabernardez@git.wordpress.org>
Co-authored-by: SH4LIN <sh4lin@git.wordpress.org>
Co-authored-by: lunule <lunule@git.wordpress.org>
Co-authored-by: cloudcreationsjess <onmauitime@git.wordpress.org>
  • Loading branch information
45 people authored Apr 22, 2024
1 parent 13deab0 commit aa5cdae
Show file tree
Hide file tree
Showing 9 changed files with 72 additions and 7 deletions.
1 change: 1 addition & 0 deletions packages/base-styles/_z-index.scss
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

$z-layers: (
".block-editor-block-list__block::before": 0,
".block-editor-block-list__block.is-selected": 20,
".block-editor-block-switcher__arrow": 1,
".block-editor-block-list__block {core/image aligned wide or fullwide}": 20,
".block-library-classic__toolbar": 31, // When scrolled to top this toolbar needs to sit over block-editor-block-toolbar
Expand Down
8 changes: 8 additions & 0 deletions packages/block-editor/src/components/block-list/content.scss
Original file line number Diff line number Diff line change
Expand Up @@ -183,6 +183,14 @@ _::-webkit-full-page-media, _:future, :root .has-multi-selection .block-editor-b
user-select: none;
}

&.has-negative-margin {
&.is-selected,
&.has-child-selected {
// Bring the selected block forward so we can see it.
z-index: z-index(".block-editor-block-list__block.is-selected");
}
}

.reusable-block-edit-panel * {
z-index: z-index(".block-editor-block-list__block .reusable-block-edit-panel *");
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,16 @@ export function useBlockProps( props = {}, { __unstableIsHtml } = {} ) {
);
}

let hasNegativeMargin = false;
if (
wrapperProps?.style?.marginTop?.charAt( 0 ) === '-' ||
wrapperProps?.style?.marginBottom?.charAt( 0 ) === '-' ||
wrapperProps?.style?.marginLeft?.charAt( 0 ) === '-' ||
wrapperProps?.style?.marginRight?.charAt( 0 ) === '-'
) {
hasNegativeMargin = true;
}

return {
tabIndex: blockEditingMode === 'disabled' ? -1 : 0,
...wrapperProps,
Expand Down Expand Up @@ -174,6 +184,7 @@ export function useBlockProps( props = {}, { __unstableIsHtml } = {} ) {
'can-insert-moving-block': canInsertMovingBlock,
'is-editing-disabled': isEditingDisabled,
'has-editable-outline': hasEditableOutline,
'has-negative-margin': hasNegativeMargin,
'is-content-locked-temporarily-editing-as-blocks':
isTemporarilyEditingAsBlocks,
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -561,6 +561,7 @@ export default function DimensionsPanel( {
<BoxControl
values={ marginValues }
onChange={ setMarginValues }
min={ -Infinity }
label={ __( 'Margin' ) }
sides={ marginSides }
units={ units }
Expand All @@ -574,6 +575,7 @@ export default function DimensionsPanel( {
<SpacingSizesControl
values={ marginValues }
onChange={ setMarginValues }
minimumCustomValue={ -Infinity }
label={ __( 'Margin' ) }
sides={ marginSides }
units={ units }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,8 @@ export default function SpacingInputControl( {
! isValueSpacingPreset( value )
);

const [ minValue, setMinValue ] = useState( minimumCustomValue );

const previousValue = usePrevious( value );
if (
!! value &&
Expand Down Expand Up @@ -222,13 +224,26 @@ export default function SpacingInputControl( {
}
value={ currentValue }
units={ units }
min={ minimumCustomValue }
min={ minValue }
placeholder={ allPlaceholder }
disableUnits={ isMixed }
label={ ariaLabel }
hideLabelFromVision
className="spacing-sizes-control__custom-value-input"
size={ '__unstable-large' }
onDragStart={ () => {
if ( value?.charAt( 0 ) === '-' ) {
setMinValue( 0 );
}
} }
onDrag={ () => {
if ( value?.charAt( 0 ) === '-' ) {
setMinValue( 0 );
}
} }
onDragEnd={ () => {
setMinValue( minimumCustomValue );
} }
/>
<RangeControl
onMouseOver={ onMouseOver }
Expand Down
5 changes: 5 additions & 0 deletions packages/block-library/src/group/style.scss
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,8 @@
// This block has customizable padding, border-box makes that more predictable.
box-sizing: border-box;
}

// We need this so groups with negative margins overlap as expected.
:where(.wp-block-group.wp-block-group-is-layout-constrained) {
position: relative;
}
4 changes: 4 additions & 0 deletions packages/components/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@

## Unreleased

### Enhancements

- `BoxControl`: Allow negative values for margin controls ([#60347](https://github.com/WordPress/gutenberg/pull/60347)).

### Bug Fix

- `SlotFill`: fixed missing `getServerSnapshot` parameter in slot map ([#60943](https://github.com/WordPress/gutenberg/pull/60943)).
Expand Down
11 changes: 5 additions & 6 deletions packages/components/src/box-control/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,10 +34,6 @@ import type {
BoxControlValue,
} from './types';

const defaultInputProps = {
min: 0,
};

const noop = () => {};

function useUniqueId( idProp?: string ) {
Expand Down Expand Up @@ -74,7 +70,6 @@ function useUniqueId( idProp?: string ) {
function BoxControl( {
__next40pxDefaultSize = false,
id: idProp,
inputProps = defaultInputProps,
onChange = noop,
label = __( 'Box Control' ),
values: valuesProp,
Expand All @@ -85,6 +80,7 @@ function BoxControl( {
resetValues = DEFAULT_VALUES,
onMouseOver,
onMouseOut,
...inputProps
}: BoxControlProps ) {
const [ values, setValues ] = useControlledState( valuesProp, {
fallback: DEFAULT_VALUES,
Expand Down Expand Up @@ -140,8 +136,11 @@ function BoxControl( {
setIsDirty( false );
};

const min = 'min' in inputProps ? inputProps.min : 0;
const newInputProps = { ...inputProps, min };

const inputControlProps = {
...inputProps,
newInputProps,
onChange: handleOnChange,
onFocus: handleOnFocus,
isLinked,
Expand Down
20 changes: 20 additions & 0 deletions packages/components/src/box-control/input-controls.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
* WordPress dependencies
*/
import { useInstanceId } from '@wordpress/compose';
import { useState } from '@wordpress/element';
/**
* Internal dependencies
*/
Expand All @@ -28,6 +29,8 @@ export default function BoxInputControls( {
sides,
...props
}: BoxControlInputControlProps ) {
const minimumCustomValue = props.min;
const [ minValue, setMinValue ] = useState( minimumCustomValue );
const generatedId = useInstanceId( BoxInputControls, 'box-control-input' );

const createHandleOnFocus =
Expand Down Expand Up @@ -100,6 +103,9 @@ export default function BoxInputControls( {
? parsedUnit
: selectedUnits[ side ];

const isNegativeValue =
parsedQuantity !== undefined && parsedQuantity < 0;

const inputId = [ generatedId, side ].join( '-' );

return (
Expand All @@ -115,6 +121,7 @@ export default function BoxInputControls( {
value={ [ parsedQuantity, computedUnit ].join(
''
) }
min={ minValue }
onChange={ ( nextValue, extra ) =>
handleOnValueChange(
side,
Expand All @@ -126,6 +133,19 @@ export default function BoxInputControls( {
side
) }
onFocus={ createHandleOnFocus( side ) }
onDragStart={ () => {
if ( isNegativeValue ) {
setMinValue( 0 );
}
} }
onDrag={ () => {
if ( isNegativeValue ) {
setMinValue( 0 );
}
} }
onDragEnd={ () => {
setMinValue( minimumCustomValue );
} }
label={ LABELS[ side ] }
hideLabelFromVision
/>
Expand Down

0 comments on commit aa5cdae

Please sign in to comment.