Skip to content

Commit

Permalink
Implemented mechanism to use classes for configured colors instead of…
Browse files Browse the repository at this point in the history
… inline styles.
  • Loading branch information
jorgefilipecosta committed Mar 29, 2018
1 parent 112c752 commit 9b99d2e
Show file tree
Hide file tree
Showing 10 changed files with 270 additions and 33 deletions.
2 changes: 1 addition & 1 deletion blocks/color-palette/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ export function ColorPalette( { colors, disableCustomColors = false, value, onCh

return (
<div className="blocks-color-palette">
{ map( colors, ( color ) => {
{ map( colors, ( { color } ) => {
const style = { color: color };
const className = classnames( 'blocks-color-palette__item', { 'is-active': value === color } );

Expand Down
2 changes: 1 addition & 1 deletion blocks/color-palette/test/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import { shallow } from 'enzyme';
import { ColorPalette } from '../';

describe( 'ColorPalette', () => {
const colors = [ 'red', 'white', 'blue' ];
const colors = [ { name: 'red', color: 'red' }, { name: 'white', color: 'white' }, { name: 'blue', color: 'blue' } ];
const currentColor = 'red';
const onChange = jest.fn();

Expand Down
2 changes: 2 additions & 0 deletions blocks/colors/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
export { getColorClass } from './utils';
export { default as withColors } from './with-colors';
87 changes: 87 additions & 0 deletions blocks/colors/style.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
.has-pale-pink-background-color {
background-color: #f78da7;
}

.has-vivid-red-background-color {
background-color: #cf2e2e;
}

.has-luminous-vivid-orange-background-color {
background-color: #ff6900;
}

.has-luminous-vivid-amber-background-color {
background-color: #fcb900;
}

.has-light-green-cyan-background-color {
background-color: #7bdcb5;
}

.has-vivid-green-cyan-background-color {
background-color: #00d084;
}

.has-pale-cyan-blue-background-color {
background-color: #8ed1fc;
}

.has-vivid-cyan-blue-background-color {
background-color: #0693e3;
}

.has-very-light-gray-background-color {
background-color: #eeeeee;
}

.has-cyan-bluish-gray-background-color {
background-color: #abb8c3;
}

.has-very-dark-gray-background-color {
background-color: #313131;
}

.has-pale-pink-text-color {
color: #f78da7;
}

.has-vivid-red-text-color {
color: #cf2e2e;
}

.has-luminous-vivid-orange-text-color {
color: #ff6900;
}

.has-luminous-vivid-amber-text-color {
color: #fcb900;
}

.has-light-green-cyan-text-color {
color: #7bdcb5;
}

.has-vivid-green-cyan-text-color {
color: #00d084;
}

.has-pale-cyan-blue-text-color {
color: #8ed1fc;
}

.has-vivid-cyan-blue-text-color {
color: #0693e3;
}

.has-very-light-gray-text-color {
color: #eeeeee;
}

.has-cyan-bluish-gray-text-color {
color: #abb8c3;
}

.has-very-dark-gray-text-color {
color: #313131;
}
39 changes: 39 additions & 0 deletions blocks/colors/utils.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
/**
* External dependencies
*/
import { find, kebabCase } from 'lodash';

export const getColorValue = ( colors, namedColor, customColor ) => {
if ( namedColor ) {
const colorObj = find( colors, { name: namedColor } );
return colorObj && colorObj.color;
}
if ( customColor ) {
return customColor;
}
};

export const setColorValue = ( colors, colorAttributeName, customColorAttributeName, setAttributes ) =>
( colorValue ) => {
const colorObj = find( colors, { color: colorValue } );
setAttributes( {
[ colorAttributeName ]: colorObj ? colorObj.name : undefined,
[ customColorAttributeName ]: colorObj ? undefined : colorValue,
} );
};

/**
* Returns a class based on the context a color is being used and its name.
*
* @param {string} colorContextName Context/place where color is being used e.g: background, text etc...
* @param {string} colorName Name of the color.
*
* @return {string} String with the class corresponding to the color in the provided context.
*/
export function getColorClass( colorContextName, colorName ) {
if ( ! colorContextName || ! colorName ) {
return;
}

return `has-${ kebabCase( colorName ) }-${ colorContextName }-color`;
}
49 changes: 49 additions & 0 deletions blocks/colors/with-colors.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
/**
* External dependencies
*/
import { get } from 'lodash';

/**
* WordPress dependencies
*/
import { getWrapperDisplayName } from '@wordpress/element';
import { withContext } from '@wordpress/components';

/**
* Internal dependencies
*/
import { getColorValue, getColorClass, setColorValue } from './utils';
import './style.scss';

/**
* Higher-order component, which handles color logic for class generation
* color value, retrieval and color attribute setting.
*
* @param {WPElement} WrappedComponent The wrapped component.
*
* @return {Component} Component with a new colors prop.
*/
export default function withColors( WrappedComponent ) {
const ComponentWithColorContext = withContext( 'editor' )(
( settings, props ) => {
const colors = get( settings, [ 'colors' ], [] );
return {
initializeColor: ( { colorContext, colorAttribute, customColorAttribute } ) => ( {
value: getColorValue(
colors,
props.attributes[ colorAttribute ],
props.attributes[ customColorAttribute ]
),
class: getColorClass( colorContext, props.attributes[ colorAttribute ] ),
set: setColorValue( colors, colorAttribute, customColorAttribute, props.setAttributes ),
} ),
};
} )( WrappedComponent );

const EnhancedComponent = ( props ) => {
return <ComponentWithColorContext { ...props } />;
};
EnhancedComponent.displayName = getWrapperDisplayName( ComponentWithColorContext, 'colorMechanism' );

return EnhancedComponent;
}
1 change: 1 addition & 0 deletions blocks/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import './hooks';
// Blocks are inferred from the HTML source of a post through a parsing mechanism
// and then stored as objects in state, from which it is then rendered for editing.
export * from './api';
export * from './colors';
export { registerCoreBlocks } from './library';
export { default as AlignmentToolbar } from './alignment-toolbar';
export { default as BlockAlignmentToolbar } from './block-alignment-toolbar';
Expand Down
2 changes: 1 addition & 1 deletion blocks/library/paragraph/editor.scss
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
.editor-block-list__block:not( .is-multi-selected ) .wp-block-paragraph {
.editor-block-list__block:not( .is-multi-selected ) .wp-block-paragraph:not( .has-background ) {
background: white;
}

Expand Down
65 changes: 46 additions & 19 deletions blocks/library/paragraph/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ import RichText from '../../rich-text';
import InspectorControls from '../../inspector-controls';
import ColorPalette from '../../color-palette';
import ContrastChecker from '../../contrast-checker';
import { getColorClass, withColors } from '../../colors';

const { getComputedStyle } = window;

Expand Down Expand Up @@ -129,20 +130,30 @@ class ParagraphBlock extends Component {
mergeBlocks,
onReplace,
className,
initializeColor,
} = this.props;

const {
align,
content,
dropCap,
placeholder,
backgroundColor,
textColor,
width,
} = attributes;

const fontSize = this.getFontSize();

const textColor = initializeColor( {
colorContext: 'text',
colorAttribute: 'textColor',
customColorAttribute: 'customTextColor',
} );
const backgroundColor = initializeColor( {
colorContext: 'background',
colorAttribute: 'backgroundColor',
customColorAttribute: 'customBackgroundColor',
} );

return [
isSelected && (
<BlockControls key="controls">
Expand Down Expand Up @@ -198,22 +209,22 @@ class ParagraphBlock extends Component {
onChange={ this.toggleDropCap }
/>
</PanelBody>
<PanelColor title={ __( 'Background Color' ) } colorValue={ backgroundColor } initialOpen={ false }>
<PanelColor title={ __( 'Background Color' ) } colorValue={ backgroundColor.value } initialOpen={ false }>
<ColorPalette
value={ backgroundColor }
onChange={ ( colorValue ) => setAttributes( { backgroundColor: colorValue } ) }
value={ backgroundColor.value }
onChange={ backgroundColor.set }
/>
</PanelColor>
<PanelColor title={ __( 'Text Color' ) } colorValue={ textColor } initialOpen={ false }>
<PanelColor title={ __( 'Text Color' ) } colorValue={ textColor.value } initialOpen={ false }>
<ColorPalette
value={ textColor }
onChange={ ( colorValue ) => setAttributes( { textColor: colorValue } ) }
value={ textColor.value }
onChange={ textColor.set }
/>
</PanelColor>
{ this.nodeRef && <ContrastCheckerWithFallbackStyles
node={ this.nodeRef }
textColor={ textColor }
backgroundColor={ backgroundColor }
textColor={ textColor.value }
backgroundColor={ backgroundColor.value }
isLargeText={ fontSize >= 18 }
/> }
<PanelBody title={ __( 'Block Alignment' ) }>
Expand All @@ -233,12 +244,14 @@ class ParagraphBlock extends Component {
<RichText
tagName="p"
className={ classnames( 'wp-block-paragraph', className, {
'has-background': backgroundColor,
'has-background': backgroundColor.value,
'has-drop-cap': dropCap,
[ backgroundColor.class ]: backgroundColor.class,
[ textColor.class ]: textColor.class,
} ) }
style={ {
backgroundColor: backgroundColor,
color: textColor,
backgroundColor: backgroundColor.class ? undefined : backgroundColor.value,
color: textColor.class ? undefined : textColor.value,
fontSize: fontSize ? fontSize + 'px' : undefined,
textAlign: align,
} }
Expand Down Expand Up @@ -302,9 +315,15 @@ const schema = {
textColor: {
type: 'string',
},
customTextColor: {
type: 'string',
},
backgroundColor: {
type: 'string',
},
customBackgroundColor: {
type: 'string',
},
fontSize: {
type: 'string',
},
Expand Down Expand Up @@ -415,7 +434,7 @@ export const settings = {
}
},

edit: ParagraphBlock,
edit: withColors( ParagraphBlock ),

save( { attributes } ) {
const {
Expand All @@ -425,21 +444,29 @@ export const settings = {
dropCap,
backgroundColor,
textColor,
customBackgroundColor,
customTextColor,
fontSize,
customFontSize,
} = attributes;

const textClass = getColorClass( 'text', textColor );
const backgroundClass = getColorClass( 'background', backgroundColor );
const fontSizeClass = fontSize && FONT_SIZES[ fontSize ] && `is-${ fontSize }-text`;

const className = classnames( {
[ `align${ width }` ]: width,
'has-background': backgroundColor,
'has-background': backgroundColor || customBackgroundColor,
'has-drop-cap': dropCap,
[ `is-${ fontSize }-text` ]: fontSize && FONT_SIZES[ fontSize ],
[ fontSizeClass ]: fontSizeClass,
[ textClass ]: textClass,
[ backgroundClass ]: backgroundClass,
} );

const styles = {
backgroundColor: backgroundColor,
color: textColor,
fontSize: ! fontSize && customFontSize ? customFontSize : undefined,
backgroundColor: backgroundClass ? undefined : customBackgroundColor,
color: textClass ? undefined : customTextColor,
fontSize: fontSizeClass ? undefined : customFontSize,
textAlign: align,
};

Expand Down
Loading

0 comments on commit 9b99d2e

Please sign in to comment.