Skip to content

Commit

Permalink
Implement changes in site editor / global styles comparable to PHP ch…
Browse files Browse the repository at this point in the history
…anges
  • Loading branch information
andrewserong committed May 17, 2022
1 parent 8c6acf1 commit 4492cd7
Show file tree
Hide file tree
Showing 5 changed files with 36 additions and 13 deletions.
9 changes: 6 additions & 3 deletions packages/block-editor/src/layouts/flex.js
Original file line number Diff line number Diff line change
Expand Up @@ -115,8 +115,11 @@ export default {
const blockGapValue =
style?.spacing?.blockGap &&
! shouldSkipSerialization( blockName, 'spacing', 'blockGap' )
? getGapCSSValue( style?.spacing?.blockGap, '0.5em' )
: 'var( --wp--style--block-gap, 0.5em )'; // TODO: If there's a value set at the block level in theme.json, how do we ensure this value doesn't override that?
? `gap: ${ getGapCSSValue(
style?.spacing?.blockGap,
'0.5em'
) };`
: '';
const justifyContent =
justifyContentMap[ layout.justifyContent ] ||
justifyContentMap.left;
Expand All @@ -143,7 +146,7 @@ export default {
${ appendSelectors( selector ) } {
display: flex;
flex-wrap: ${ flexWrap };
gap: ${ hasBlockGapStylesSupport ? blockGapValue : '0.5em' };
${ hasBlockGapStylesSupport ? blockGapValue : 'gap: 0.5em;' }
${ orientation === 'horizontal' ? rowOrientation : columnOrientation }
}
Expand Down
7 changes: 5 additions & 2 deletions packages/block-editor/src/layouts/flow.js
Original file line number Diff line number Diff line change
Expand Up @@ -125,7 +125,7 @@ export default {
blockGapStyleValue?.top &&
! shouldSkipSerialization( blockName, 'spacing', 'blockGap' )
? blockGapStyleValue?.top
: 'var( --wp--style--block-gap )';
: '';

let output =
!! contentSize || !! wideSize
Expand Down Expand Up @@ -165,12 +165,15 @@ export default {
}
`;

if ( hasBlockGapStylesSupport ) {
if ( hasBlockGapStylesSupport && blockGapValue ) {
output += `
${ appendSelectors( selector, '> *' ) } {
margin-block-start: 0;
margin-block-end: 0;
}
`;

output += `
${ appendSelectors( selector, '> * + *' ) } {
margin-block-start: ${ blockGapValue };
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,13 +43,8 @@ function useHasMargin( name ) {
function useHasGap( name ) {
const supports = getSupportedGlobalStylesPanels( name );
const [ settings ] = useSetting( 'spacing.blockGap', name );
// Do not show the gap control panel for block-level global styles
// as they do not work on the frontend.
// See: https://github.com/WordPress/gutenberg/pull/39845.
// We can revert this condition when they're working again.
return !! name
? false
: settings && supports.includes( '--wp--style--block-gap' );

return settings && supports.includes( '--wp--style--block-gap' );
}

function filterValuesBySides( values, sides ) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ import { __unstablePresetDuotoneFilter as PresetDuotoneFilter } from '@wordpress
/**
* Internal dependencies
*/
import { PRESET_METADATA, ROOT_BLOCK_SELECTOR } from './utils';
import { LAYOUT_STYLES, PRESET_METADATA, ROOT_BLOCK_SELECTOR } from './utils';
import { GlobalStylesContext } from './context';
import { useSetting } from './hooks';

Expand Down Expand Up @@ -391,6 +391,21 @@ export const toStyles = ( tree, blockSelectors, hasBlockGapSupport ) => {
`${ duotoneSelector }{${ duotoneDeclarations.join( ';' ) };}`;
}

// Process blockGap styles.
if ( styles?.spacing?.blockGap ) {
const gapValue = styles.spacing.blockGap;
delete styles.spacing.blockGap;
Object.entries( LAYOUT_STYLES[ '--wp--style--block-gap' ] ).forEach(
( [ additionalSelector, cssProperty ] ) => {
const combinedSelector =
selector === ROOT_BLOCK_SELECTOR
? `${ selector } ${ additionalSelector }`
: `${ selector }${ additionalSelector }`;
ruleset += `${ combinedSelector } { ${ cssProperty }: ${ gapValue }; }`;
}
);
}

// Process the remaning block styles (they use either normal block class or __experimentalSelector).
const declarations = getStylesDeclarations( styles );
if ( declarations.length === 0 ) {
Expand Down
7 changes: 7 additions & 0 deletions packages/edit-site/src/components/global-styles/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,13 @@ export const ROOT_BLOCK_SUPPORTS = [
'padding',
];

export const LAYOUT_STYLES = {
'--wp--style--block-gap': {
'.is-layout-flex': 'gap',
'.is-layout-flow > * + *': 'margin-top',
},
};

export const PRESET_METADATA = [
{
path: [ 'color', 'palette' ],
Expand Down

0 comments on commit 4492cd7

Please sign in to comment.