Skip to content

Commit

Permalink
Add transform between cover and media & text (#38458)
Browse files Browse the repository at this point in the history
* Add transform between cover and media & text

* Add align

* Remove use of set

* Maintain text color transforming from media to cover (#40666)

Co-authored-by: Aaron Robertshaw <[email protected]>
  • Loading branch information
Petter Walbø Johnsgård and aaronrobertshaw authored May 9, 2022
1 parent 1dfc080 commit fe3a4d5
Showing 1 changed file with 154 additions and 0 deletions.
154 changes: 154 additions & 0 deletions packages/block-library/src/media-text/transforms.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,61 @@ const transforms = {
anchor,
} ),
},
{
type: 'block',
blocks: [ 'core/cover' ],
transform: (
{
align,
alt,
anchor,
backgroundType,
customGradient,
customOverlayColor,
gradient,
id,
overlayColor,
url,
},
innerBlocks
) => {
let additionalAttributes = {};

if ( customGradient ) {
additionalAttributes = {
style: {
color: {
gradient: customGradient,
},
},
};
} else if ( customOverlayColor ) {
additionalAttributes = {
style: {
color: {
background: customOverlayColor,
},
},
};
}

return createBlock(
'core/media-text',
{
align,
anchor,
backgroundColor: overlayColor,
gradient,
mediaAlt: alt,
mediaId: id,
mediaType: backgroundType,
mediaUrl: url,
...additionalAttributes,
},
innerBlocks
);
},
},
],
to: [
{
Expand Down Expand Up @@ -59,6 +114,105 @@ const transforms = {
} );
},
},
{
type: 'block',
blocks: [ 'core/cover' ],
transform: (
{
align,
anchor,
backgroundColor,
focalPoint,
gradient,
mediaAlt,
mediaId,
mediaType,
mediaUrl,
style,
textColor,
},
innerBlocks
) => {
const additionalAttributes = {};

if ( style?.color?.gradient ) {
additionalAttributes.customGradient = style.color.gradient;
} else if ( style?.color?.background ) {
additionalAttributes.customOverlayColor =
style.color.background;
}

const coverAttributes = {
align,
alt: mediaAlt,
anchor,
backgroundType: mediaType,
dimRatio: !! mediaUrl ? 50 : 100,
focalPoint,
gradient,
id: mediaId,
overlayColor: backgroundColor,
url: mediaUrl,
...additionalAttributes,
};
const customTextColor = style?.color?.text;

// Attempt to maintain any text color selection.
// Cover block's do not opt into color block support so we
// cannot directly copy the color attributes across.
if ( ! textColor && ! customTextColor ) {
return createBlock(
'core/cover',
coverAttributes,
innerBlocks
);
}

const coloredInnerBlocks = innerBlocks.map( ( innerBlock ) => {
const {
attributes: { style: innerStyle },
} = innerBlock;

// Only apply the media and text color if the inner block
// doesn't set its own color block support selection.
if (
innerBlock.attributes.textColor ||
innerStyle?.color?.text
) {
return innerBlock;
}

const newAttributes = { textColor };

// Only add or extend inner block's style object if we have
// a custom text color from the media & text block.
if ( customTextColor ) {
newAttributes.style = {
...innerStyle,
color: {
...innerStyle?.color,
text: customTextColor,
},
};
}

return createBlock(
innerBlock.name,
{
...innerBlock.attributes,
...newAttributes,
},
innerBlock.innerBlocks
);
} );

return createBlock(
'core/cover',
coverAttributes,
coloredInnerBlocks
);
},
},
],
};

Expand Down

0 comments on commit fe3a4d5

Please sign in to comment.