The Building Blocks of Building Blocks
Rich Tabor + JR Tashjian + Evan Herman + Anthony Ledesma
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
GitHub: http://github.com/richtabor/building-blocks
Download the project + add it to your local environment (or Docker, via the instructions in the project)
data:image/s3,"s3://crabby-images/47e3a/47e3afb6655fcd298c21a1fafff7a8a196edd7c2" alt=""
Welcome to the wonderful world of blocks!
data:image/s3,"s3://crabby-images/47e3a/47e3afb6655fcd298c21a1fafff7a8a196edd7c2" alt=""
Rich Tabor
data:image/s3,"s3://crabby-images/1412a/1412a1debde47e0978cb2e8cf761041e383fe66c" alt=""
Senior Product Manager, WordPress Experience @ GoDaddy
CoBlocks Co-Founder – ThemeBeans Founder – Joined GoDaddy April 2019
JR Tashjian
data:image/s3,"s3://crabby-images/2fac1/2fac17afcdff48829aee33f3be6bc6ed489e4d56" alt=""
Product Engineer, WordPress Experience @ GoDaddy
Full Stack Engineer – WordPress & Gutenberg Contributor
Evan Herman
data:image/s3,"s3://crabby-images/ea777/ea777b66da4607ee91ed30c84c05a11850df952d" alt=""
Product Engineer, WordPress Experience @ GoDaddy
WordPress specialist – Lover of APIs – Cat Herder
Anthony Ledesma
data:image/s3,"s3://crabby-images/7c61d/7c61d449a85b22895e75f4afb55c827f31bcdadb" alt=""
Product Engineer, WordPress Experience @ GoDaddy
Full Stack Engineer – WordPress & Gutenberg Contributor
data:image/s3,"s3://crabby-images/9e605/9e60597ff88598b6c6e80a49d6087972dc4f58ba" alt=""
data:image/s3,"s3://crabby-images/9e605/9e60597ff88598b6c6e80a49d6087972dc4f58ba" alt=""
data:image/s3,"s3://crabby-images/965ba/965ba8e63da0d19a4c7e8fdda1e0d744e8516f22" alt=""
data:image/s3,"s3://crabby-images/9e605/9e60597ff88598b6c6e80a49d6087972dc4f58ba" alt=""
Walk outta here with a better understanding of block development
Today's Goal:
data:image/s3,"s3://crabby-images/aef68/aef682474507aaaf9d94c0a72b93f3da0a4054a0" alt=""
Learn Javascript
data:image/s3,"s3://crabby-images/342a8/342a85ebe88cd304ed2dc78c9afb12f3525c55d3" alt=""
data:image/s3,"s3://crabby-images/6a964/6a964e75ad5d802a3490ea785d1351412f407ebb" alt=""
Learn UX
data:image/s3,"s3://crabby-images/342a8/342a85ebe88cd304ed2dc78c9afb12f3525c55d3" alt=""
data:image/s3,"s3://crabby-images/642a5/642a566b57f3123d196c5188358881f2b6b771fb" alt=""
Learning Block Fundamentals and Core UX Patterns
Which we'll tackle today!
data:image/s3,"s3://crabby-images/be51d/be51d1a8da4013549f8b0179ad4964d72f14c4b5" alt=""
How this workshop will work
data:image/s3,"s3://crabby-images/f54f8/f54f8147afe7eea6d7add2189c0f8204b2c1ea9f" alt=""
Slides
slides.com/richtabor/building-blocks
GitHub Project
github.com/richtabor/building-blocks
Ask Questions!
data:image/s3,"s3://crabby-images/fd45e/fd45e2904b1ca6b387331f04bae40d50ed715e16" alt=""
The fundamentals of Block Development
data:image/s3,"s3://crabby-images/47e3a/47e3afb6655fcd298c21a1fafff7a8a196edd7c2" alt=""
The Anatomy of a Block
data:image/s3,"s3://crabby-images/0ccd3/0ccd3eb817cf98f5568ac506a11bd8b8dd6af1ca" alt=""
What are blocks?
Simply put: a unit for "editable stuff" within the WordPress block editor
Block Assets
Registering JS & CSS Assets for a block
├── your-plugin.php
├── package.json
├── build
├── index.js
├── style.css
├── editor.css
└── src
├── block.js
├── edit.js
├── icon.js
├── index.js
├── save.js
├── style.scss
├── editor.scss
// Block Javascript
wp_register_script(
'building-blocks',
plugins_url( 'build/index.js', __FILE__ ),
$asset_file['dependencies'],
$asset_file['version'],
);
// Editor Styling
wp_register_style(
'building-blocks-editor',
plugins_url( 'editor.css', __FILE__ ),
array( 'wp-edit-blocks' ),
$asset_file['version']
);
// Frontend Styling
wp_register_style(
'building-blocks-frontend',
plugins_url( 'style.css', __FILE__ ),
array(),
$asset_file['version']
);
// Register block
register_block_type(
'building-blocks/author',
array(
'editor_script' => 'building-blocks',
'style' => 'building-blocks-frontend',
'editor_style' => 'building-blocks-editor',
)
);
A Closer look at Block Registration
data:image/s3,"s3://crabby-images/15c35/15c353b7ee0dfce9996130f068e591f81a997c61" alt=""
registerBlockType( 'building-blocks/author', {
title: __( 'Building Blocks (Author)', 'building-blocks' ),
icon: 'user',
category: 'common',
example: {},
attributes: {},
edit() {
return (
<div>Hello from the editor</div>
);
},
save() {
return (
<div>Hello from the front-end</div>
);
},
} );
Block Attributes you say?
attributes: {
content: {
type: 'array',
source: 'children',
selector: 'p',
},
alignment: {
type: 'string',
default: 'none',
},
},
Edit Function
edit: ( props ) => {
const { attributes: { content }, setAttributes, className } = props;
const onChangeContent = ( newContent ) => {
setAttributes( { content: newContent } );
};
return (
<RichText
tagName="p"
className={ className }
onChange={ onChangeContent }
value={ content }
/>
);
},
Save Function, i.e. the Front-end
save: ( props ) => {
return <RichText.Content tagName="p" value={ props.attributes.content } />;
},
Exercise Time!
data:image/s3,"s3://crabby-images/fd45e/fd45e2904b1ca6b387331f04bae40d50ed715e16" alt=""
data:image/s3,"s3://crabby-images/28f2f/28f2f3aa8c9d5da425a6ca3cecb015dbfa45c491" alt=""
Partner up!
data:image/s3,"s3://crabby-images/da2d7/da2d74af9c3b6983e69a6e04cb09a0ed0a8b1937" alt=""
Setup
GOAL
Exercise is downloaded from GitHub and running locally
docker-compose up -d
http://localhost:9999/
Setup
GOAL
- Install node packages
- Start it up
Exercise is running locally with node packages installed
npm install
npm start
Add author block markup and styling
Step 1
Step 1A & 1B
Add Author markup for both save and edit functions
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 1C
Add primary styling in the style.css stylesheet
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 1D
Add editor styling in the editor.css stylesheet
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Add editable RichText components
Step 2
Step 2A
Add block.json for registering block attributes
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 2B
Import block.json metadata into registerBlockType
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 2C
Add RichText component to the edit function
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 2D
Add RichText component to the save function
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Add MediaUpload component
Step 3
Step 3A
Add media attributes to block.json
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 3B
Add MediaUpload to the edit function
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 3C
Add editor styling for the MediaUpload component
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 3D
Update save function with media attributes
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Add BlockControls toolbar controls
Step 4
Step 4A
Add Fragment component wrapper
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 4B
Add BlockControls for editing current avatar image
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Add Sidebar InspectorControls
Step 5
Step 5A
Add mediaAlt attribute to block.json
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 5B
Add InspectorControls framework for Settings Sidebar
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 5C
Add TextareaControl for mediaALT
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 5D
Add mediaALT to edit and save functions
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Add alternate block styles
Step 6
Step 6A
Add styles to registerBlockType function
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 6B
Add new style styling to primary stylesheet
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 6C
Add editor styling for the new square style
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Add DropZone support
Step 7
Step 7A
Add DropZone component and logic
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 7B
Remove the older onSelectImage const
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 7C
Add Spinner for isBlobURL image uploader
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Add background color support
Step 8
Step 8A
Add background color attributes to block.json
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 8B
Add logic for background color in the edit function
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 8C
Add appropriate fallback background color
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 8D
Add PanelColorSettings for background color
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Step 8E
Add colors to front-end in the save function
Slides: http://slides.com/richtabor/building-blocks
Need help later? I'm on Twitter @richard_tabor
data:image/s3,"s3://crabby-images/5a3f0/5a3f0d1d48ed0ddc9fda2be6a496b1f1cbc58bc1" alt=""
data:image/s3,"s3://crabby-images/e6d08/e6d08b0dd56be7843de34837e00c787e93275a15" alt=""
Great Job!
data:image/s3,"s3://crabby-images/9129e/9129e7ec57a8034fe1dde0bea8c6e95ff6b8512c" alt=""
Questions?
data:image/s3,"s3://crabby-images/fd45e/fd45e2904b1ca6b387331f04bae40d50ed715e16" alt=""
The Building Blocks of Building Blocks
By richtabor
The Building Blocks of Building Blocks
Let’s dive in and learn how to build Gutenberg blocks for WordPress with Javascript. We’ll explore the foundations of the block development, how to setup a local block development environment and actually build a block or two using the latest techniques, block controls and settings panels. You’ll leave the workshop with a clear understanding of the building blocks of building blocks.
- 3,494