From 795ec0da1358e492abfbf6a71e99428251edb4b5 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Mon, 8 Oct 2018 09:44:26 +0100 Subject: [PATCH 1/4] Move the Classic block to the packages --- bin/build-plugin-zip.sh | 1 - bin/get-server-blocks.php | 3 - block-library/editor.scss | 1 - block-library/index.js | 101 ------------------ block-library/index.native.js | 4 - block-library/style.scss | 1 - block-library/theme.scss | 1 - lib/client-assets.php | 4 +- packages/block-library/src/editor.scss | 1 + .../block-library/src}/freeform/edit.js | 5 - .../block-library/src}/freeform/editor.scss | 0 .../block-library/src}/freeform/index.js | 0 .../freeform/test/__snapshots__/index.js.snap | 0 .../block-library/src}/freeform/test/index.js | 2 +- packages/block-library/src/index.js | 14 ++- phpcs.xml.dist | 1 - .../__mocks__/@wordpress/block-library.js | 5 + test/unit/jest.config.json | 4 +- webpack.config.js | 44 +------- 19 files changed, 25 insertions(+), 167 deletions(-) delete mode 100644 block-library/editor.scss delete mode 100644 block-library/index.js delete mode 100644 block-library/index.native.js delete mode 100644 block-library/style.scss delete mode 100644 block-library/theme.scss rename {block-library => packages/block-library/src}/freeform/edit.js (98%) rename {block-library => packages/block-library/src}/freeform/editor.scss (100%) rename {block-library => packages/block-library/src}/freeform/index.js (100%) rename {block-library => packages/block-library/src}/freeform/test/__snapshots__/index.js.snap (100%) rename {block-library => packages/block-library/src}/freeform/test/index.js (75%) create mode 100644 test/unit/__mocks__/@wordpress/block-library.js diff --git a/bin/build-plugin-zip.sh b/bin/build-plugin-zip.sh index 40e265eaa51ed9..1339b8ccec2b8e 100755 --- a/bin/build-plugin-zip.sh +++ b/bin/build-plugin-zip.sh @@ -120,7 +120,6 @@ status "Creating archive... 🎁" zip -r gutenberg.zip \ gutenberg.php \ lib/*.php \ - block-library/*/*.php \ packages/block-library/src/*/*.php \ packages/block-serialization-default-parser/*.php \ post-content.php \ diff --git a/bin/get-server-blocks.php b/bin/get-server-blocks.php index 8e3b2060183811..851dbccfab6e6d 100755 --- a/bin/get-server-blocks.php +++ b/bin/get-server-blocks.php @@ -30,9 +30,6 @@ require_once dirname( dirname( __FILE__ ) ) . '/lib/client-assets.php'; // Register server-side code for individual blocks. -foreach ( glob( dirname( dirname( __FILE__ ) ) . '/block-library/*/index.php' ) as $block_logic ) { - require_once $block_logic; -} foreach ( glob( dirname( dirname( __FILE__ ) ) . '/packages/block-library/src/*/index.php' ) as $block_logic ) { require_once $block_logic; } diff --git a/block-library/editor.scss b/block-library/editor.scss deleted file mode 100644 index 764dac8ca8da9b..00000000000000 --- a/block-library/editor.scss +++ /dev/null @@ -1 +0,0 @@ -@import "../packages/block-library/src/editor.scss"; diff --git a/block-library/index.js b/block-library/index.js deleted file mode 100644 index 03bdbe13466dcf..00000000000000 --- a/block-library/index.js +++ /dev/null @@ -1,101 +0,0 @@ -/** - * WordPress dependencies - */ -import { - registerBlockType, - setDefaultBlockName, - setUnknownTypeHandlerName, -} from '@wordpress/blocks'; - -/** - * Internal dependencies - */ -import './style.scss'; -import './editor.scss'; -import './theme.scss'; -import * as paragraph from '../packages/block-library/src/paragraph'; -import * as image from '../packages/block-library/src/image'; -import * as heading from '../packages/block-library/src/heading'; -import * as quote from '../packages/block-library/src/quote'; -import * as gallery from '../packages/block-library/src/gallery'; -import * as archives from '../packages/block-library/src/archives'; -import * as audio from '../packages/block-library/src/audio'; -import * as button from '../packages/block-library/src/button'; -import * as categories from '../packages/block-library/src/categories'; -import * as code from '../packages/block-library/src/code'; -import * as columns from '../packages/block-library/src/columns'; -import * as column from '../packages/block-library/src/columns/column'; -import * as coverImage from '../packages/block-library/src/cover-image'; -import * as embed from '../packages/block-library/src/embed'; -import * as file from '../packages/block-library/src/file'; -import * as html from '../packages/block-library/src/html'; -import * as latestComments from '../packages/block-library/src/latest-comments'; -import * as latestPosts from '../packages/block-library/src/latest-posts'; -import * as list from '../packages/block-library/src/list'; -import * as more from '../packages/block-library/src/more'; -import * as nextpage from '../packages/block-library/src/nextpage'; -import * as preformatted from '../packages/block-library/src/preformatted'; -import * as pullquote from '../packages/block-library/src/pullquote'; -import * as reusableBlock from '../packages/block-library/src/block'; -import * as separator from '../packages/block-library/src/separator'; -import * as shortcode from '../packages/block-library/src/shortcode'; -import * as spacer from '../packages/block-library/src/spacer'; -import * as subhead from '../packages/block-library/src/subhead'; -import * as table from '../packages/block-library/src/table'; -import * as template from '../packages/block-library/src/template'; -import * as textColumns from '../packages/block-library/src/text-columns'; -import * as verse from '../packages/block-library/src/verse'; -import * as video from '../packages/block-library/src/video'; - -// The freeform block can't be moved to the "npm" packages folder because it requires the wp.oldEditor global. -import * as freeform from './freeform'; - -export const registerCoreBlocks = () => { - [ - // Common blocks are grouped at the top to prioritize their display - // in various contexts — like the inserter and auto-complete components. - paragraph, - image, - heading, - gallery, - list, - quote, - - // Register all remaining core blocks. - shortcode, - archives, - audio, - button, - categories, - code, - columns, - column, - coverImage, - embed, - ...embed.common, - ...embed.others, - file, - freeform, - html, - latestComments, - latestPosts, - more, - nextpage, - preformatted, - pullquote, - separator, - reusableBlock, - spacer, - subhead, - table, - template, - textColumns, - verse, - video, - ].forEach( ( { name, settings } ) => { - registerBlockType( name, settings ); - } ); - - setDefaultBlockName( paragraph.name ); - setUnknownTypeHandlerName( freeform.name ); -}; diff --git a/block-library/index.native.js b/block-library/index.native.js deleted file mode 100644 index 3779a1214f53ac..00000000000000 --- a/block-library/index.native.js +++ /dev/null @@ -1,4 +0,0 @@ -/** - * Internal dependencies - */ -import '../packages/block-library/src'; diff --git a/block-library/style.scss b/block-library/style.scss deleted file mode 100644 index 7afe88dde1f2bd..00000000000000 --- a/block-library/style.scss +++ /dev/null @@ -1 +0,0 @@ -@import "../packages/block-library/src/style.scss"; diff --git a/block-library/theme.scss b/block-library/theme.scss deleted file mode 100644 index 39f6af550322ce..00000000000000 --- a/block-library/theme.scss +++ /dev/null @@ -1 +0,0 @@ -@import "../packages/block-library/src/theme.scss"; diff --git a/lib/client-assets.php b/lib/client-assets.php index e7b09ae9733067..f3cd1b427d411a 100644 --- a/lib/client-assets.php +++ b/lib/client-assets.php @@ -731,14 +731,14 @@ function gutenberg_register_scripts_and_styles() { wp_register_style( 'wp-edit-blocks', - gutenberg_url( 'build/block-library/edit-blocks.css' ), + gutenberg_url( 'build/block-library/editor.css' ), array( 'wp-components', 'wp-editor', // Always include visual styles so the editor never appears broken. 'wp-block-library-theme', ), - filemtime( gutenberg_dir_path() . 'build/block-library/edit-blocks.css' ) + filemtime( gutenberg_dir_path() . 'build/block-library/editor.css' ) ); wp_style_add_data( 'wp-edit-blocks', 'rtl', 'replace' ); diff --git a/packages/block-library/src/editor.scss b/packages/block-library/src/editor.scss index 94ac00322dca9d..33b9640ffd06c3 100644 --- a/packages/block-library/src/editor.scss +++ b/packages/block-library/src/editor.scss @@ -7,6 +7,7 @@ @import "./cover-image/editor.scss"; @import "./embed/editor.scss"; @import "./file/editor.scss"; +@import "./freeform/editor.scss"; @import "./gallery/editor.scss"; @import "./heading/editor.scss"; @import "./html/editor.scss"; diff --git a/block-library/freeform/edit.js b/packages/block-library/src/freeform/edit.js similarity index 98% rename from block-library/freeform/edit.js rename to packages/block-library/src/freeform/edit.js index 6fa71e20e1ec5a..ed95bfba1deac5 100644 --- a/block-library/freeform/edit.js +++ b/packages/block-library/src/freeform/edit.js @@ -5,11 +5,6 @@ import { Component } from '@wordpress/element'; import { __, _x } from '@wordpress/i18n'; import { BACKSPACE, DELETE, F10 } from '@wordpress/keycodes'; -/** - * Internal dependencies - */ -import './editor.scss'; - function isTmceEmpty( editor ) { // When tinyMce is empty the content seems to be: //


diff --git a/block-library/freeform/editor.scss b/packages/block-library/src/freeform/editor.scss similarity index 100% rename from block-library/freeform/editor.scss rename to packages/block-library/src/freeform/editor.scss diff --git a/block-library/freeform/index.js b/packages/block-library/src/freeform/index.js similarity index 100% rename from block-library/freeform/index.js rename to packages/block-library/src/freeform/index.js diff --git a/block-library/freeform/test/__snapshots__/index.js.snap b/packages/block-library/src/freeform/test/__snapshots__/index.js.snap similarity index 100% rename from block-library/freeform/test/__snapshots__/index.js.snap rename to packages/block-library/src/freeform/test/__snapshots__/index.js.snap diff --git a/block-library/freeform/test/index.js b/packages/block-library/src/freeform/test/index.js similarity index 75% rename from block-library/freeform/test/index.js rename to packages/block-library/src/freeform/test/index.js index 36e3735c12bc75..824c835543e7bc 100644 --- a/block-library/freeform/test/index.js +++ b/packages/block-library/src/freeform/test/index.js @@ -2,7 +2,7 @@ * Internal dependencies */ import { name, settings } from '../'; -import { blockEditRender } from '../../../packages/block-library/src/test/helpers'; +import { blockEditRender } from '../../test/helpers'; describe( 'core/freeform', () => { test( 'block edit matches snapshot', () => { diff --git a/packages/block-library/src/index.js b/packages/block-library/src/index.js index a2991cebedb0de..6a861cec524e19 100644 --- a/packages/block-library/src/index.js +++ b/packages/block-library/src/index.js @@ -5,6 +5,7 @@ import '@wordpress/core-data'; import { registerBlockType, setDefaultBlockName, + setUnknownTypeHandlerName, } from '@wordpress/blocks'; /** @@ -44,6 +45,9 @@ import * as textColumns from './text-columns'; import * as verse from './verse'; import * as video from './video'; +// The freeform block can't be moved to the "npm" packages folder because it requires the wp.oldEditor global. +import * as freeform from './freeform'; + export const registerCoreBlocks = () => { [ // Common blocks are grouped at the top to prioritize their display @@ -69,6 +73,7 @@ export const registerCoreBlocks = () => { ...embed.common, ...embed.others, file, + window.wp && window.wp.oldEditor ? freeform : null, // Only add the freeform block in WP Context html, latestComments, latestPosts, @@ -85,9 +90,16 @@ export const registerCoreBlocks = () => { textColumns, verse, video, - ].forEach( ( { name, settings } ) => { + ].forEach( ( block ) => { + if ( ! block ) { + return; + } + const { name, settings } = block; registerBlockType( name, settings ); } ); setDefaultBlockName( paragraph.name ); + if ( window.wp && window.wp.oldEditor ) { + setUnknownTypeHandlerName( freeform.name ); + } }; diff --git a/phpcs.xml.dist b/phpcs.xml.dist index a7cfc9de314379..ce0669fe42a39f 100644 --- a/phpcs.xml.dist +++ b/phpcs.xml.dist @@ -22,7 +22,6 @@ ./bin - ./block-library ./packages/block-library/src ./lib ./lib/parser.php diff --git a/test/unit/__mocks__/@wordpress/block-library.js b/test/unit/__mocks__/@wordpress/block-library.js new file mode 100644 index 00000000000000..1b452e9b4e06de --- /dev/null +++ b/test/unit/__mocks__/@wordpress/block-library.js @@ -0,0 +1,5 @@ +// Make sure the freeform block is registered. +window.wp = window.wp || {}; +window.wp.oldEditor = {}; + +export * from '../../../../packages/block-library/src'; diff --git a/test/unit/jest.config.json b/test/unit/jest.config.json index 095317caed655d..fbab20dac0d773 100644 --- a/test/unit/jest.config.json +++ b/test/unit/jest.config.json @@ -1,7 +1,7 @@ { "rootDir": "../../", "collectCoverageFrom": [ - "(edit-post|block-library)/**/*.js", + "(edit-post)/**/*.js", "packages/**/*.js" ], "coveragePathIgnorePatterns": [ @@ -13,7 +13,7 @@ "/gutenberg-mobile/" ], "moduleNameMapper": { - "@wordpress\\/(components|edit-post|block-library)$": "$1", + "@wordpress\\/(components|edit-post)$": "$1", "@wordpress\\/(block-serialization-spec-parser|is-shallow-equal)$": "packages/$1", "@wordpress\\/([a-z0-9-]+)$": "packages/$1/src" }, diff --git a/webpack.config.js b/webpack.config.js index 1bc044099563fa..15dbd779cca286 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -21,21 +21,6 @@ const mainCSSExtractTextPlugin = new ExtractTextPlugin( { filename: './build/[basename]/style.css', } ); -// CSS loader for styles specific to block editing. -const editBlocksCSSPlugin = new ExtractTextPlugin( { - filename: './build/block-library/edit-blocks.css', -} ); - -// CSS loader for styles specific to blocks in general. -const blocksCSSPlugin = new ExtractTextPlugin( { - filename: './build/block-library/style.css', -} ); - -// CSS loader for default visual block styles. -const themeBlocksCSSPlugin = new ExtractTextPlugin( { - filename: './build/block-library/theme.css', -} ); - // Configuration for the ExtractTextPlugin. const extractConfig = { use: [ @@ -78,7 +63,6 @@ function camelCaseDash( string ) { const entryPointNames = [ 'components', 'edit-post', - 'block-library', ]; const gutenbergPackages = [ @@ -87,6 +71,7 @@ const gutenbergPackages = [ 'autop', 'blob', 'blocks', + 'block-library', 'block-serialization-default-parser', 'block-serialization-spec-parser', 'compose', @@ -182,40 +167,13 @@ const config = { ], use: 'babel-loader', }, - { - test: /style\.s?css$/, - include: [ - /block-library/, - ], - use: blocksCSSPlugin.extract( extractConfig ), - }, - { - test: /editor\.s?css$/, - include: [ - /block-library/, - ], - use: editBlocksCSSPlugin.extract( extractConfig ), - }, - { - test: /theme\.s?css$/, - include: [ - /block-library/, - ], - use: themeBlocksCSSPlugin.extract( extractConfig ), - }, { test: /\.s?css$/, - exclude: [ - /block-library/, - ], use: mainCSSExtractTextPlugin.extract( extractConfig ), }, ], }, plugins: [ - blocksCSSPlugin, - editBlocksCSSPlugin, - themeBlocksCSSPlugin, mainCSSExtractTextPlugin, // Create RTL files with a -rtl suffix new WebpackRTLPlugin( { From fe0ada0b73ef402242da5868f80ff4fa13bdfdba Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Mon, 8 Oct 2018 16:32:35 +0100 Subject: [PATCH 2/4] Rename freeform => classic --- packages/block-library/src/{freeform => classic}/edit.js | 4 ++-- .../block-library/src/{freeform => classic}/editor.scss | 2 +- packages/block-library/src/{freeform => classic}/index.js | 0 .../{freeform => classic}/test/__snapshots__/index.js.snap | 2 +- .../block-library/src/{freeform => classic}/test/index.js | 0 packages/block-library/src/index.js | 7 +++---- test/unit/__mocks__/@wordpress/block-library.js | 2 +- 7 files changed, 8 insertions(+), 9 deletions(-) rename packages/block-library/src/{freeform => classic}/edit.js (98%) rename packages/block-library/src/{freeform => classic}/editor.scss (99%) rename packages/block-library/src/{freeform => classic}/index.js (100%) rename packages/block-library/src/{freeform => classic}/test/__snapshots__/index.js.snap (87%) rename packages/block-library/src/{freeform => classic}/test/index.js (100%) diff --git a/packages/block-library/src/freeform/edit.js b/packages/block-library/src/classic/edit.js similarity index 98% rename from packages/block-library/src/freeform/edit.js rename to packages/block-library/src/classic/edit.js index ed95bfba1deac5..6bede6a2df3183 100644 --- a/packages/block-library/src/freeform/edit.js +++ b/packages/block-library/src/classic/edit.js @@ -21,7 +21,7 @@ function isTmceEmpty( editor ) { return /^\n?$/.test( body.innerText || body.textContent ); } -export default class FreeformEdit extends Component { +export default class ClassicEdit extends Component { constructor( props ) { super( props ); this.initialize = this.initialize.bind( this ); @@ -171,7 +171,7 @@ export default class FreeformEdit extends Component { key="toolbar" id={ `toolbar-${ clientId }` } ref={ ( ref ) => this.ref = ref } - className="freeform-toolbar" + className="block-library-classic__toolbar" onClick={ this.focus } data-placeholder={ __( 'Classic' ) } onKeyDown={ this.onToolbarKeyDown } diff --git a/packages/block-library/src/freeform/editor.scss b/packages/block-library/src/classic/editor.scss similarity index 99% rename from packages/block-library/src/freeform/editor.scss rename to packages/block-library/src/classic/editor.scss index 9c03b0667461d2..70c8e819c2169b 100644 --- a/packages/block-library/src/freeform/editor.scss +++ b/packages/block-library/src/classic/editor.scss @@ -144,7 +144,7 @@ div[data-type="core/freeform"] .editor-block-contextual-toolbar + div { padding-top: 0; } -.freeform-toolbar { +.block-library-classic__toolbar { width: auto; margin: 0 #{ -$block-padding }; position: sticky; diff --git a/packages/block-library/src/freeform/index.js b/packages/block-library/src/classic/index.js similarity index 100% rename from packages/block-library/src/freeform/index.js rename to packages/block-library/src/classic/index.js diff --git a/packages/block-library/src/freeform/test/__snapshots__/index.js.snap b/packages/block-library/src/classic/test/__snapshots__/index.js.snap similarity index 87% rename from packages/block-library/src/freeform/test/__snapshots__/index.js.snap rename to packages/block-library/src/classic/test/__snapshots__/index.js.snap index c14bc40ad32de8..690b0d5e30fdd1 100644 --- a/packages/block-library/src/freeform/test/__snapshots__/index.js.snap +++ b/packages/block-library/src/classic/test/__snapshots__/index.js.snap @@ -3,7 +3,7 @@ exports[`core/freeform block edit matches snapshot 1`] = ` Array [
, diff --git a/packages/block-library/src/freeform/test/index.js b/packages/block-library/src/classic/test/index.js similarity index 100% rename from packages/block-library/src/freeform/test/index.js rename to packages/block-library/src/classic/test/index.js diff --git a/packages/block-library/src/index.js b/packages/block-library/src/index.js index 6a861cec524e19..3c71cb52c702a4 100644 --- a/packages/block-library/src/index.js +++ b/packages/block-library/src/index.js @@ -45,8 +45,7 @@ import * as textColumns from './text-columns'; import * as verse from './verse'; import * as video from './video'; -// The freeform block can't be moved to the "npm" packages folder because it requires the wp.oldEditor global. -import * as freeform from './freeform'; +import * as classic from './classic'; export const registerCoreBlocks = () => { [ @@ -73,7 +72,7 @@ export const registerCoreBlocks = () => { ...embed.common, ...embed.others, file, - window.wp && window.wp.oldEditor ? freeform : null, // Only add the freeform block in WP Context + window.wp && window.wp.oldEditor ? classic : null, // Only add the classic block in WP Context html, latestComments, latestPosts, @@ -100,6 +99,6 @@ export const registerCoreBlocks = () => { setDefaultBlockName( paragraph.name ); if ( window.wp && window.wp.oldEditor ) { - setUnknownTypeHandlerName( freeform.name ); + setUnknownTypeHandlerName( classic.name ); } }; diff --git a/test/unit/__mocks__/@wordpress/block-library.js b/test/unit/__mocks__/@wordpress/block-library.js index 1b452e9b4e06de..72c9351ad7dad9 100644 --- a/test/unit/__mocks__/@wordpress/block-library.js +++ b/test/unit/__mocks__/@wordpress/block-library.js @@ -1,4 +1,4 @@ -// Make sure the freeform block is registered. +// Make sure the classic block is registered. window.wp = window.wp || {}; window.wp.oldEditor = {}; From 03b5920b6d694d81a28dc677ab2d78997ea0dcf8 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Mon, 8 Oct 2018 16:33:54 +0100 Subject: [PATCH 3/4] Update the changelog of the block library package --- packages/block-library/CHANGELOG.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/packages/block-library/CHANGELOG.md b/packages/block-library/CHANGELOG.md index 43b9b38ee17c6f..1c11ea8435e06f 100644 --- a/packages/block-library/CHANGELOG.md +++ b/packages/block-library/CHANGELOG.md @@ -1,3 +1,9 @@ +## 2.1.0 (Unreleased) + +### New Features + +- Include the classic block if `wp.oldEditor` is defined. + ## 2.0.0 (2018-09-05) ### Breaking Change From 8cf3ccc8f4767b7fbe763c8eefa6ab7ffb227ef8 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Mon, 8 Oct 2018 16:50:24 +0100 Subject: [PATCH 4/4] Fix classic block editor styles --- packages/block-library/src/editor.scss | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/block-library/src/editor.scss b/packages/block-library/src/editor.scss index 33b9640ffd06c3..70aa75c35b7f05 100644 --- a/packages/block-library/src/editor.scss +++ b/packages/block-library/src/editor.scss @@ -7,7 +7,7 @@ @import "./cover-image/editor.scss"; @import "./embed/editor.scss"; @import "./file/editor.scss"; -@import "./freeform/editor.scss"; +@import "./classic/editor.scss"; @import "./gallery/editor.scss"; @import "./heading/editor.scss"; @import "./html/editor.scss";