Skip to content

Commit

Permalink
Docs: Update docs to reflect the change in how block controls are han…
Browse files Browse the repository at this point in the history
…dled
  • Loading branch information
gziolo committed Mar 12, 2018
1 parent 3d612a0 commit 44b9536
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 25 deletions.
22 changes: 7 additions & 15 deletions blocks/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -275,12 +275,6 @@ buttons. This is useful for block-level modifications to be made available when
a block is selected. For example, if your block supports alignment, you may
want to display alignment options in the selected block's toolbar.

Because the toolbar should only be shown when the block is selected, it is
important that a `BlockControls` element is only returned when the block's
`isSelected` prop is
[truthy](https://developer.mozilla.org/en-US/docs/Glossary/Truthy),
meaning that the block is currently selected.

Example:

```js
Expand All @@ -292,15 +286,13 @@ Example:
function edit( props ) {
return [
// Controls: (only visible when block is selected)
props.isSelected && (
el( BlockControls, { key: 'controls' },
el( AlignmentToolbar, {
value: props.align,
onChange: function( nextAlign ) {
props.setAttributes( { align: nextAlign } )
}
} )
)
el( BlockControls, { key: 'controls' },
el( AlignmentToolbar, {
value: props.align,
onChange: function( nextAlign ) {
props.setAttributes( { align: nextAlign } )
}
} )
),

// Block content: (with alignment as attribute)
Expand Down
18 changes: 8 additions & 10 deletions docs/blocks-controls.md
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ registerBlockType( 'gutenberg-boilerplate-es5/hello-world-step-04', {
}

return [
isSelected && el(
el(
BlockControls,
{ key: 'controls' },
el(
Expand Down Expand Up @@ -124,14 +124,12 @@ registerBlockType( 'gutenberg-boilerplate-esnext/hello-world-step-04', {
}

return [
isSelected && (
<BlockControls key="controls">
<AlignmentToolbar
value={ alignment }
onChange={ onChangeAlignment }
/>
</BlockControls>
),
<BlockControls key="controls">
<AlignmentToolbar
value={ alignment }
onChange={ onChangeAlignment }
/>
</BlockControls>,
<RichText
key="editable"
tagName="p"
Expand All @@ -152,7 +150,7 @@ registerBlockType( 'gutenberg-boilerplate-esnext/hello-world-step-04', {
```
{% end %}

Note that you should only include `BlockControls` if the block is currently selected. We must test that the `isSelected` value is truthy before rendering the element, otherwise you will inadvertently cause controls to be shown for the incorrect block type.
Note that `BlockControls` is only visible when the block is currently selected.

## Inspector

Expand Down

0 comments on commit 44b9536

Please sign in to comment.