Skip to content
This repository has been archived by the owner on Feb 23, 2024. It is now read-only.

Commit

Permalink
Add global styles to Product Title block (#5009)
Browse files Browse the repository at this point in the history
Co-authored-by: Albert Juhé Lluveras <[email protected]>
  • Loading branch information
dinhtungdu and Aljullu authored Oct 28, 2021
1 parent 2f2ac00 commit 76901d7
Show file tree
Hide file tree
Showing 7 changed files with 45 additions and 128 deletions.
47 changes: 21 additions & 26 deletions assets/js/atomic/blocks/product-elements/title/block.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import {
} from '@woocommerce/shared-context';
import { getColorClassName, getFontSizeClass } from '@wordpress/block-editor';
import { isFeaturePluginBuild } from '@woocommerce/block-settings';
import { gatedStyledText } from '@woocommerce/atomic-utils';
import { withProductDataContext } from '@woocommerce/shared-hocs';
import ProductName from '@woocommerce/base-components/product-name';
import { useStoreEvents } from '@woocommerce/base-context/hooks';
Expand Down Expand Up @@ -39,15 +38,14 @@ const TagName = ( {
/**
* Product Title Block Component.
*
* @param {Object} props Incoming props.
* @param {string} [props.className] CSS Class name for the component.
* @param {number} [props.headingLevel] Heading level (h1, h2 etc)
* @param {boolean} [props.showProductLink] Whether or not to display a link to the product page.
* @param {string} [props.align] Title alignment.
* @param {string} [props.color] Title color name.
* @param {string} [props.customColor] Custom title color value.
* @param {string} [props.fontSize] Title font size name.
* @param {number } [props.customFontSize] Custom font size value.
* @param {Object} props Incoming props.
* @param {string} [props.className] CSS Class name for the component.
* @param {number} [props.headingLevel] Heading level (h1, h2 etc)
* @param {boolean} [props.showProductLink] Whether or not to display a link to the product page.
* @param {string} [props.align] Title alignment.
* @param {string} [props.textColor] Title color name.
* @param {string} [props.fontSize] Title font size name.
* @param {string} [props.style] Title inline style.
* will be used if this is not provided.
* @return {*} The component.
*/
Expand All @@ -56,25 +54,29 @@ export const Block = ( {
headingLevel = 2,
showProductLink = true,
align,
color,
customColor,
textColor,
fontSize,
customFontSize,
style,
}: Props ): JSX.Element => {
const { parentClassName } = useInnerBlockLayoutContext();
const { product } = useProductDataContext();
const { dispatchStoreEvent } = useStoreEvents();

const colorClass = getColorClassName( 'color', color );
const colorClass = getColorClassName( 'color', textColor );
const fontSizeClass = getFontSizeClass( fontSize );

const titleClasses = classnames( {
'has-text-color': color || customColor,
'has-font-size': fontSize || customFontSize,
const titleClasses = classnames( 'wp-block-woocommerce-product-title', {
'has-text-color': textColor || style?.color?.text || style?.color,
[ `has-font-size` ]:
fontSize || style?.typography?.fontSize || style?.fontSize,
[ colorClass ]: colorClass,
[ fontSizeClass ]: fontSizeClass,
} );

const titleStyle = {
fontSize: style?.fontSize || style?.typography?.fontSize,
color: style?.color?.text || style?.color,
};

if ( ! product.id ) {
return (
<TagName
Expand All @@ -89,10 +91,6 @@ export const Block = ( {
[ titleClasses ]: isFeaturePluginBuild(),
}
) }
style={ gatedStyledText( {
color: customColor,
fontSize: customFontSize,
} ) }
/>
);
}
Expand All @@ -118,15 +116,12 @@ export const Block = ( {
name={ product.name }
permalink={ product.permalink }
rel={ showProductLink ? 'nofollow' : '' }
style={ gatedStyledText( {
color: customColor,
fontSize: customFontSize,
} ) }
onClick={ () => {
dispatchStoreEvent( 'product-view-link', {
product,
} );
} }
style={ isFeaturePluginBuild() ? titleStyle : {} }
/>
</TagName>
);
Expand Down
65 changes: 6 additions & 59 deletions assets/js/atomic/blocks/product-elements/title/edit.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,13 @@
* External dependencies
*/
import { __ } from '@wordpress/i18n';
import {
ColorPalette,
Disabled,
PanelBody,
ToggleControl,
} from '@wordpress/components';
import { Disabled, PanelBody, ToggleControl } from '@wordpress/components';
import { compose } from '@wordpress/compose';
import {
InspectorControls,
BlockControls,
AlignmentToolbar,
withColors,
PanelColorSettings,
FontSizePicker,
withFontSizes,
useBlockProps,
} from '@wordpress/block-editor';
import { isFeaturePluginBuild } from '@woocommerce/block-settings';
import HeadingToolbar from '@woocommerce/editor-components/heading-toolbar';
Expand All @@ -30,27 +22,15 @@ import { BLOCK_TITLE, BLOCK_ICON } from './constants';
import { Attributes } from './types';

interface Props {
color: ColorPalette.Color;
fontSize: {
size: number | undefined;
};
setFontSize: ( size: number ) => void;
setColor: ( color: ColorPalette.Color ) => void;
attributes: Attributes;
setAttributes: ( attributes: Record< string, unknown > ) => void;
}

const TitleEdit = ( {
color,
fontSize,
setFontSize,
setColor,
attributes,
setAttributes,
}: Props ): JSX.Element => {
const TitleEdit = ( { attributes, setAttributes }: Props ): JSX.Element => {
const blockProps = useBlockProps();
const { headingLevel, showProductLink, align } = attributes;
return (
<>
<div { ...blockProps }>
<BlockControls>
<HeadingToolbar
isCollapsed={ true }
Expand Down Expand Up @@ -91,49 +71,16 @@ const TitleEdit = ( {
}
/>
</PanelBody>
{ isFeaturePluginBuild() && (
<>
<PanelBody
title={ __(
'Text settings',
'woo-gutenberg-products-block'
) }
>
<FontSizePicker
value={ fontSize.size }
onChange={ setFontSize }
/>
</PanelBody>
<PanelColorSettings
title={ __(
'Color settings',
'woo-gutenberg-products-block'
) }
colorSettings={ [
{
value: color,
onChange: setColor,
label: __(
'Text color',
'woo-gutenberg-products-block'
),
},
] }
></PanelColorSettings>
</>
) }
</InspectorControls>
<Disabled>
<Block { ...attributes } />
</Disabled>
</>
</div>
);
};

const Title = isFeaturePluginBuild()
? compose( [
withFontSizes( 'fontSize' ),
withColors( 'color', { textColor: 'color' } ),
withProductSelector( {
icon: BLOCK_ICON,
label: BLOCK_TITLE,
Expand Down
13 changes: 13 additions & 0 deletions assets/js/atomic/blocks/product-elements/title/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
* External dependencies
*/
import { registerBlockType, BlockConfiguration } from '@wordpress/blocks';
import { isFeaturePluginBuild } from '@woocommerce/block-settings';

/**
* Internal dependencies
Expand All @@ -17,6 +18,7 @@ import {

const blockConfig: BlockConfiguration = {
...sharedConfig,
apiVersion: 2,
title,
description,
icon: {
Expand All @@ -25,6 +27,17 @@ const blockConfig: BlockConfiguration = {
},
attributes,
edit,
supports: isFeaturePluginBuild()
? {
html: false,
color: {
background: false,
},
typography: {
fontSize: true,
},
}
: sharedConfig.supports,
};

registerBlockType( 'woocommerce/product-title', blockConfig );
12 changes: 0 additions & 12 deletions assets/js/atomic/utils/block-styling.js

This file was deleted.

1 change: 0 additions & 1 deletion assets/js/atomic/utils/index.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
export * from './get-block-map';
export * from './create-blocks-from-template';
export * from './render-parent-block';
export * from './block-styling';
export * from './render-standalone-blocks';
1 change: 1 addition & 0 deletions assets/js/base/components/product-name/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ export default ( {
dangerouslySetInnerHTML={ {
__html: decodeEntities( name ),
} }
style={ style }
/>
);
};
34 changes: 4 additions & 30 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 76901d7

Please sign in to comment.