In this article, I’ll show you how I used Wicked Block Builder Pro to create the owl-link block as part of the #OwlLinkChallenge.
Getting Started
First off, I’m using Wicked Block Builder Pro. Wicked Block Builder Pro is a WordPress plugin that makes it super easy to create your own custom WordPress blocks. If you’re interested, you can use the discount code OWLS to get 10% off Wicked Block Builder Pro.
Creating the Block
The first step is to create the block. This part is easy and I did that by going to Wicked Block Builder > Add New.
Configure Settings
You can learn more about the various settings in the Wicked Block Builder documentation. For this block, the only setting I had to enter was the block name (‘Owl Link’ in this case).
data:image/s3,"s3://crabby-images/6e27d/6e27da6f8b85cf68521d96a28acc95d119b52d42" alt="Block settings"
Set Up Attributes
Next, I added some attributes to the block. Attributes can be added by clicking or dragging an attribute type. I added a number attribute to hold the ID of our block’s image and called it ‘imageId’. I also added two more string attributes: one named ‘content’ and another named ‘link’.
data:image/s3,"s3://crabby-images/bffce/bffcee89c228268beaebacd66815a17b57b8feaf" alt="Block attributes"
Build the Block Editor View
I wanted the final output of my block to look something like this:
<div class="owl-link">
<img class="owl-link__image" src="example.jpg" alt="An image">
<div class="owl-link__content">
<p>
<!-- Summary here... -->
</p>
<p class="owl-link__link">
<!-- Link here... -->
</p>
</div>
</div>
In Wicked Block Builder, you control your block’s HTML structure by dragging HTML elements and components. So, to start, I added a div
element to the block structure. Clicking on an element lets you adjust its settings and add things like classes, inline styles, and HTML attributes. I wanted the containing div to have a class of ‘owl-link’ so I clicked the ‘Add Class’ button in the Classes panel and entered the class name.
Next, I added an Image component. Image components let you select an image when your block is displayed in the WordPress editor. When the block is rendered, the Image component outputs an <img>
tag. I mapped the Image component to the imageId
attribute so that the selected image would be stored in that attribute.
I added a nested div, this time adding the class owl-link__content
.
Finally, I added two RichText components to the owl-link__content
div: one mapped to the ‘content’ attribute and another mapped to the ‘link’ attribute. RichText components let you type content directly into your block inside of the WordPress page editor.
data:image/s3,"s3://crabby-images/ad885/ad8850e88d85d516f9744a87886b08c29c3a38bf" alt="Block editor view"
Build the Block Front-end View
One of the nice things about Wicked Block Builder is that you want your block to use the same output on the front-end as the back-end, you can skip the step of creating a separate front-end view and Wicked Block Builder will generate it for you automatically. So I skipped the step of creating the front-end view.
Style the Block
Lastly, I added the following CSS to the Styles tab in the block builder:
/**
* Front-end styles
*/
.owl-link {
display: flex;
gap: 20px;
}
.owl-link .owl-link__image {
border-radius: 20px;
height: auto;
max-width: 25%;
}
.owl-link .owl-link__content {
border: 1px solid rgba(0,0,0,0.3);
border-radius: 20px;
padding: 20px;
margin: 0px;
width: 100%;
background: rgba(0,0,0,0.1);
}
.owl-link .owl-link__content p:first-of-type {
margin-bottom: 20px;
margin-top: 0px;
}
.owl-link .owl-link__content p:last-of-type {
margin-bottom: 0px;
}
.owl-link.is-style-owl-link__no-border .owl-link__content {
border: none;
padding: 0px;
}
.owl-link .owl-link__link {
text-transform: uppercase;
font-weight: bold;
}
/**
* Editor tweaks
*/
.owl-link .wbb-image {
max-width: 25%;
}
.owl-link .wbb-image .owl-link__image {
max-width: 100%;
}
data:image/s3,"s3://crabby-images/86b37/86b37258f532f095f74182da68c90d0e5660c3c8" alt="Block CSS"
Test the Block
At this point, all we should have to do is hit Save and we should be able to insert our block into a page. I opened up my sample page and inserted the block. Presto, a block!
data:image/s3,"s3://crabby-images/0188a/0188ae90e42106b0eacee397271dbbde922f7032" alt="The owl-link block inserted into the page"
Adding a Border Variation
In Matt’s original article about creating the owl-link block, he showed how style variations could be used to create two different variations of the block: one with a border around the content, and another without the border.
Wicked Block Builder has a conditional logic feature that makes it easy to conditionally output CSS classes, inline styles, HTML attributes, or even entire portions of your block. In this case, I wanted a way to select between a ‘Border’ and ‘No border’ style.
Adding a New Attribute
The first thing I had to do was add a new attribute to the block to store the selected style variation. I called the attribute ‘border’.
data:image/s3,"s3://crabby-images/89331/89331d78c612c944614888b5dd1cdce4f53b500d" alt="The block attributes with the new border attribute added"
Adding a Sidebar Panel
I think the block sidebar is great for block settings that don’t change frequently. Wicked Block Builder makes it easy to add items to your block’s sidebar. I went ahead and added a panel component and gave it a label of ‘Settings’. Next, I added a Radios component to the panel, mapped it to the ‘border’ attribute, and added choices for ‘Border’ and ‘No border’ (I used ‘no_border’ for the ‘No border’ choice value).
data:image/s3,"s3://crabby-images/b83eb/b83eba303da9bff166896e52df6976332a67f5ec" alt="Block sidebar with panel and radio control added"
Conditionally Outputting the CSS Class
Finally, I needed a way to add a CSS class to the block when the no border style was selected. To do this, I added another class called ‘is-style-owl-link__no-border’ to the block containing div; however, this time I added a condition to the class to control when it was output. I added a condition for when the border attribute value equals ‘no_border’ which means that the class would only be output when that option is selected.
data:image/s3,"s3://crabby-images/41997/419976c8358f3b429556ea832c7936e2fa8ed2bd" alt="CSS class to hide border with condition applied"
Conclusion
There are a lot of different ways to create blocks: patterns, React, this plugin, and more. The implementation of my owl-link block was a little different from the original but the end result was the same and I think that’s what’s important. It was a fun challenge and thanks to Matt Watson and WP Owls for publishing a great article on how to create a custom block. If there’s one thing I think we can all agree on, it’s that more documentation and tutorials on how to create blocks is never a bad thing.