Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update Blocks Tutorial to match Gutenberg Examples #14584

Merged
merged 17 commits into from
Mar 28, 2019
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,48 +1,56 @@
# Applying Styles From a Stylesheet

In the previous section, the block had applied its own styles by an inline `style` attribute. While this might be adequate for very simple components, you will quickly find that it becomes easier to write your styles by extracting them to a separate stylesheet file.
In the previous step, the block had applied its own styles by an inline `style` attribute. While this might be adequate for very simple components, you will quickly find that it becomes easier to write your styles by extracting them to a separate stylesheet file.

The editor will automatically generate a class name for each block type to simplify styling. It can be accessed from the object argument passed to the edit and save functions:
The editor will automatically generate a class name for each block type to simplify styling. It can be accessed from the object argument passed to the edit and save functions. In step 2, we will create a stylesheet to use that class name.

{% codetabs %}
{% ES5 %}
```js
var el = wp.element.createElement,
mkaz marked this conversation as resolved.
Show resolved Hide resolved
registerBlockType = wp.blocks.registerBlockType;

registerBlockType( 'gutenberg-boilerplate-es5/hello-world-step-02', {
title: 'Hello World (Step 2)',
registerBlockType( 'gutenberg-examples/example-02-stylesheets', {
title: 'Example: Stylesheets',

icon: 'universal-access-alt',

category: 'layout',

edit: function( props ) {
return el( 'p', { className: props.className }, 'Hello editor.' );
return el(
'p',
{ className: props.className },
'Hello World, step 2 (from the editor, in green).'
);
},

save: function() {
return el( 'p', {}, 'Hello saved content.' );
return el(
'p',
{},
'Hello World, step 2 (from the frontend, in red).'
);
}
} );
```
{% ESNext %}
```js
const { registerBlockType } = wp.blocks;

registerBlockType( 'gutenberg-boilerplate-esnext/hello-world-step-02', {
title: 'Hello World (Step 2)',
registerBlockType( 'gutenberg-examples/example-02-stylesheets', {
title: 'Example: Stylesheets',

icon: 'universal-access-alt',

category: 'layout',

edit( { className } ) {
return <p className={ className }>Hello editor.</p>;
return <p className={ className }>Hello World, step 2 (from the editor, in green).</p>;
},

save() {
return <p>Hello saved content.</p>;
return <p>Hello World, step 2 (from the frontend, in red)./p>;
}
} );
```
Expand All @@ -51,64 +59,55 @@ registerBlockType( 'gutenberg-boilerplate-esnext/hello-world-step-02', {
The class name is generated using the block's name prefixed with `wp-block-`, replacing the `/` namespace separator with a single `-`.

```css
mkaz marked this conversation as resolved.
Show resolved Hide resolved
.wp-block-gutenberg-boilerplate-es5-hello-world-step-02 {
.wp-block-gutenberg-examples-example-02-stylesheets {
color: green;
background: #cfc;
border: 2px solid #9c9;
padding: 20px;
}
```

## Enqueueing Editor-only Block Assets
## Enqueueing Editor and Front end Assets

Like scripts, your block's editor-specific styles should be enqueued by assigning the `editor_style` setting of the registered block type.

To enqueue a style that shows on both the front of your site and the editor, use `style` setting.

When registering a block, you can assign one or both of `style` and `editor_style` to respectively assign styles always loaded for a block, or styles only loaded in the editor.

Like scripts, your block's editor-specific styles should be enqueued by assigning the `editor_styles` setting of the registered block type:
Example 2 shows having a distinct style for each context. Your block is likely to share some styles in both contexts, so in this example you can consider `style.css` as the base stylesheet, placing editor-specific styles in `editor.css`.

```php
<?php

mkaz marked this conversation as resolved.
Show resolved Hide resolved
function gutenberg_boilerplate_block() {
function gutenberg_examples_02_register_block() {
wp_register_script(
'gutenberg-boilerplate-es5-step02-editor',
plugins_url( 'step-02/block.js', __FILE__ ),
array( 'wp-blocks', 'wp-element' )
'gutenberg-examples-02',
plugins_url( 'block.js', __FILE__ ),
array( 'wp-blocks', 'wp-element' ),
filemtime( plugin_dir_path( __FILE__ ) . 'block.js' )
);

wp_register_style(
'gutenberg-boilerplate-es5-step02-editor',
plugins_url( 'step-02/editor.css', __FILE__ ),
'gutenberg-examples-02-editor',
plugins_url( 'editor.css', __FILE__ ),
array( 'wp-edit-blocks' ),
filemtime( plugin_dir_path( __FILE__ ) . 'step-02/editor.css' )
filemtime( plugin_dir_path( __FILE__ ) . 'editor.css' )
);

register_block_type( 'gutenberg-boilerplate-esnext/hello-world-step-02', array(
'editor_script' => 'gutenberg-boilerplate-es5-step02-editor',
'editor_style' => 'gutenberg-boilerplate-es5-step02-editor',
) );
}
add_action( 'init', 'gutenberg_boilerplate_block' );
```

## Enqueueing Editor and Front end Assets

While a block's scripts are usually only necessary to load in the editor, you'll want to load styles both on the front of your site and in the editor. You may even want distinct styles in each context.

When registering a block, you can assign one or both of `style` and `editor_style` to respectively assign styles always loaded for a block or styles only loaded in the editor.

```php
<?php

function gutenberg_boilerplate_block() {
wp_register_style(
'gutenberg-boilerplate-es5-step02',
plugins_url( 'step-02/style.css', __FILE__ ),
array(),
filemtime( plugin_dir_path( __FILE__ ) . 'step-02/style.css' )
'gutenberg-examples-02',
plugins_url( 'style.css', __FILE__ ),
array( ),
filemtime( plugin_dir_path( __FILE__ ) . 'style.css' )
);

register_block_type( 'gutenberg-boilerplate-esnext/hello-world-step-02', array(
'style' => 'gutenberg-boilerplate-es5-step02',
register_block_type( 'gutenberg-examples/example-02-stylesheets', array(
'style' => 'gutenberg-examples-02',
'editor_style' => 'gutenberg-examples-02-editor',
'editor_script' => 'gutenberg-examples-02',
) );
}
add_action( 'init', 'gutenberg_boilerplate_block' );
add_action( 'init', 'gutenberg_examples_02_register_block' );
```

Since your block is likely to share some styles in both contexts, you can consider `style.css` as the base stylesheet, placing editor-specific styles in `editor.css`.
Loading