Skip to content

Latest commit

 

History

History
145 lines (121 loc) · 5.43 KB

README.md

File metadata and controls

145 lines (121 loc) · 5.43 KB

ACF Gutenberg Blocks

Generate ACF Gutenberg blocks just by adding templates to your theme. This package is based heavily on this article by MWDelaney.

Installation

Add this to the composer.json:

"y-collective/acf-wp-blocks": "dev-master"
        
"repositories": [
    {
      "type": "vcs",
      "url": "https://github.com/Y-collective/acf-wp-blocks"
    }
]

Creating blocks

Add blade templates to templates/blocks which get and use ACF data. Each template requires a comment block with some data in it:

<?php
/*
  Title:
  Description:
  Category:
  Icon:
  Keywords:
  Mode:
  Align:
  PostTypes:
  SupportsAlign:
  SupportsMode:
  SupportsMultiple:
  EnqueueStyle:
  EnqueueScript:
  EnqueueAssets:
*/
?>

Example block template

<?php
/*
  Title: Testimonial
  Description: Customer testimonial
  Category: formatting
  Icon: admin-comments
  Keywords: testimonial quote
  Mode: edit
  Align: left
  PostTypes: page post
  SupportsAlign: left right
  SupportsMode: false
  SupportsMultiple: false
  EnqueueStyle: styles/style.css
  EnqueueScript: scripts/script.js
  EnqueueAssets: path/to/asset
*/
?>

<blockquote data-<?php echo $block['id'] ?> class="<?php echo $block['classes'] ?>">
    <p><?php echo  get_field('testimonial') ?></p>
    <cite>
      <span><?php echo  get_field('author') ?></span>
    </cite>
</blockquote>

<style type="text/css">
  [data-<?php echo $block['id']?>] {
    background: <?php echo  get_field('background_color') ?>;
    color: <?php echo  get_field('text_color') ?>;
  }
</style>

Data Options

The options in the file header map to options in the acf_register_block_type function.

Field Description Values Notes
Title Title of the block in the gutenberg editor i.e. Testimonial required
Description Description of the block in the gutenberg editor i.e. My testimonial block optional
Category Category to store the block in. Use these values or register your own custom block categories common, formatting, layout, widgets, embed _
required_
Icon An icon property can be specified to make it easier to identify a block. Uses dashicons i.e. book-alt _
optional_
Keywords An array of search terms to help user discover the block while searching. Sepearate values with a space. i.e. quote mention cite _
optional_
Mode The display mode for your block. auto: Preview is shown by default but changes to edit form when block is selected. preview: Preview is always shown. Edit form appears in sidebar when block is selected. edit: Edit form is always shown. auto, preview or edit _
optional_ (defaults to preview)
Align The default block alignment. left center right wide full _

optional_ (defaults to empty string) | PostTypes | An array of post types to restrict this block type to. Sepearate values with a space. | i.e. post page | | SupportsAlign | This property adds block controls which allow the user to change the block’s alignment. Set to true to show all alignments, false to hide the alignment toolbar. Set to an array (strings separated by spaces) of specific alignment names to customize the toolbar. | (boolean) true, false
or ( array) left center right wide full | _ optional_ (defaults to true) | | SupportsMode | This property allows the user to toggle between edit and preview modes via a button. | true or false |_ optional_ (defaults to true) | | SupportsMultiple | This property allows the block to be added multiple times. | true or false |_ optional_ (defaults to true) | | SupportsInnerBlocks | This property allows the block to support the nesting of other blocks within it. | true or false |_ optional_ (defaults to false) | | SupportsAlignText | This property adds an alignment toolbar button similar to that seen when editing a paragraph of text. | true or false |_ optional_ (defaults to false) | | SupportsAlignContent | This property adds an alignment toolbar button similar to that seen when editing a core "Cover block" | true or false |_ optional_ (defaults to false) |

Creating ACF fields

Once a block is created you'll be able to assign ACF fields to it using the standard Custom Fields interface in WordPress.

Filter block data

Block data can be altered via the 'yco/blocks/[block-name]/data' filter. For example, if your block template is called my-block.php, you can alter the data this way:

add_filter('yco/blocks/my-block/data', function ($block) { // Do your thing here. });

Filter template folders

By default all your template files in templates/blocks will be loaded. You can use the templates filter to add more folders if you wish. See an example below of how to add your own folders.

add_filter('yco-acf-gutenberg-blocks-templates', function ($folders) { 
    $folders[] = 'views/your-folder'; // Adds your folder
    return $folders;
});