From 4714f5d9199aefa89a922f4f6c0ce569d4b31c90 Mon Sep 17 00:00:00 2001 From: Andrew Duthie Date: Tue, 10 Jul 2018 14:26:47 -0400 Subject: [PATCH 1/2] Block Edit: Remove legacy context API child context --- editor/components/block-edit/index.js | 31 +++++---------------------- editor/components/rich-text/index.js | 6 ++++-- 2 files changed, 9 insertions(+), 28 deletions(-) diff --git a/editor/components/block-edit/index.js b/editor/components/block-edit/index.js index c5adb12ba5e4e..87ddb69ca4803 100644 --- a/editor/components/block-edit/index.js +++ b/editor/components/block-edit/index.js @@ -1,13 +1,7 @@ -/** - * External dependencies - */ -import { noop } from 'lodash'; - /** * WordPress dependencies */ -import { withSelect } from '@wordpress/data'; -import { Component, compose } from '@wordpress/element'; +import { Component } from '@wordpress/element'; /** * Internal dependencies @@ -15,24 +9,18 @@ import { Component, compose } from '@wordpress/element'; import Edit from './edit'; import { BlockEditContextProvider } from './context'; -export class BlockEdit extends Component { +class BlockEdit extends Component { constructor( props ) { super( props ); + this.setFocusedElement = this.setFocusedElement.bind( this ); + this.state = { focusedElement: null, setFocusedElement: this.setFocusedElement, }; } - getChildContext() { - const { canUserUseUnfilteredHTML } = this.props; - - return { - canUserUseUnfilteredHTML, - }; - } - setFocusedElement( focusedElement ) { this.setState( ( prevState ) => { if ( prevState.focusedElement === focusedElement ) { @@ -61,13 +49,4 @@ export class BlockEdit extends Component { } } -BlockEdit.childContextTypes = { - canUserUseUnfilteredHTML: noop, -}; - -export default compose( [ - withSelect( ( select ) => ( { - postType: select( 'core/editor' ).getEditedPostAttribute( 'type' ), - canUserUseUnfilteredHTML: select( 'core/editor' ).canUserUseUnfilteredHTML(), - } ) ), -] )( BlockEdit ); +export default BlockEdit; diff --git a/editor/components/rich-text/index.js b/editor/components/rich-text/index.js index 0d12d2dcd646b..0d0be718d5f90 100644 --- a/editor/components/rich-text/index.js +++ b/editor/components/rich-text/index.js @@ -357,7 +357,7 @@ export class RichText extends Component { plainText: this.pastedPlainText, mode, tagName: this.props.tagName, - canUserUseUnfilteredHTML: this.context.canUserUseUnfilteredHTML, + canUserUseUnfilteredHTML: this.props.canUserUseUnfilteredHTML, } ); if ( typeof content === 'string' ) { @@ -986,7 +986,6 @@ export class RichText extends Component { RichText.contextTypes = { onUndo: noop, onRedo: noop, - canUserUseUnfilteredHTML: noop, onCreateUndoLevel: noop, }; @@ -1009,6 +1008,7 @@ const RichTextContainer = compose( [ isSelected: context.isSelected, }; } + // Ensures that only one RichText component can be focused. return { isSelected: context.isSelected && context.focusedElement === ownProps.instanceId, @@ -1017,9 +1017,11 @@ const RichTextContainer = compose( [ } ), withSelect( ( select ) => { const { isViewportMatch = identity } = select( 'core/viewport' ) || {}; + const { canUserUseUnfilteredHTML } = select( 'core/editor' ); return { isViewportSmall: isViewportMatch( '< small' ), + canUserUseUnfilteredHTML: canUserUseUnfilteredHTML(), }; } ), withSafeTimeout, From 6558ece97e3eee5e65855b54750a7a9d31b8a086 Mon Sep 17 00:00:00 2001 From: Grzegorz Ziolkowski Date: Wed, 11 Jul 2018 10:18:26 +0200 Subject: [PATCH 2/2] Testing: Fix BlockEdit import --- core-blocks/test/helpers/index.js | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/core-blocks/test/helpers/index.js b/core-blocks/test/helpers/index.js index 7231a3fd0fe09..8e7aa54fda8ce 100644 --- a/core-blocks/test/helpers/index.js +++ b/core-blocks/test/helpers/index.js @@ -12,11 +12,7 @@ import { getBlockType, registerBlockType, } from '@wordpress/blocks'; -// Requiredd to register the editor's store -import '@wordpress/editor'; - -// Hack to avoid the wrapping HoCs. -import { BlockEdit } from '../../../editor/components/block-edit'; +import { BlockEdit } from '@wordpress/editor'; export const blockEditRender = ( name, settings ) => { if ( ! getBlockType( name ) ) {