Create custom Widget
data:image/s3,"s3://crabby-images/d409d/d409d52ed811358204436aa71d221b750784ff5d" alt=""
On this tutorial, I will show you how to create a custom Widget with PHP code, it’s pretty simple.
First step, open “Theme Editor” plugin, if you don’t have, you can install it from plugin repository.
data:image/s3,"s3://crabby-images/8466d/8466dfc8527ff931212fb77c60275a82d37c560d" alt=""
Select “custom.php” file, then click EDIT. Is recommended to always put custom PHP script or widgets on custom.php since custom.php will not overridden during theme update.
You will see this:
data:image/s3,"s3://crabby-images/f5919/f59194e099ba426562f70f4a7c8ffca2188b6964" alt=""
Put code below inside php tag:
class widget_sample extends Widget {
function __construct() {
$this->name = 'Sample Widget';
$this->id_base = 'sample-widget';
$this->description = 'This is sample Widget.';
}
public function widget( $instance, $args = array() ){
$html = isset($instance['html-sample']) ? $instance['html-sample'] : '';
echo "<h3>$html</h3>";
}
public function form( $instance = array() ){
if(!isset( $instance['html-sample'] )){
$instance['html-sample'] = '';
}
?>
<div class="form-group">
<label><?php _e('Test form') ?>:</label>
<input type="text" class="form-control" name="html-sample" value="<?php echo $instance['html-sample'] ?>">
</div>
<?php
}
}
register_widget( 'widget_sample' );
Explainer:
- Line 2: widget child, you can replace “widget_sample” with your widget name (lowercase, alphabet characters, no space), make sure it’s unique
- Line 4-6: Widget details, name & id_base must be unique
- Line 8: widget() is called on theme code or visitor page also can be called renderer
- Line 9: If $instance[‘html-sample’] is exist, store the value to $html, if not, put empty string instead.
- Line 10: Show $html
- Line 13: form() is called on admin panel “Layout > Widgets”, we can put widget configuration script here
- Line 15-17: Set $instance[‘html-sample’] to empty string if not exist
- Line 19-22: Widget configuration form
- Line 21: Make sure input name is same with instance name, on this sample: name=”html-sample”
- Line 26: Register the widget, if this fuction not called, your widget won’t be loaded.
Then save it
data:image/s3,"s3://crabby-images/a9eb4/a9eb4cebc0147caa480ba7ed666d6e2b7e3a4f59" alt=""
Now you can visit “Layout > Widgets” page, you will see new widget you just created.
data:image/s3,"s3://crabby-images/832b9/832b9dcff66a2d04f2b53e07b0bb95e587d4bd01" alt=""
Drag and drop “Sample Widget” into “Sidebar 1” widget placement. Fill the input field, then click save
data:image/s3,"s3://crabby-images/62f71/62f7171f98a0b321375f938ea17d26af6d05b006" alt=""
Here is the result on game page sidebar:
data:image/s3,"s3://crabby-images/3987c/3987c9aac8b9cba08ec9499051375a48e6756d1b" alt=""
You can also using built-in functions or get current page object and variables on widget()
Sample code:
class widget_sample extends Widget {
function __construct() {
$this->name = 'Sample Widget';
$this->id_base = 'sample-widget';
$this->description = 'This is sample Widget.';
}
public function widget( $instance, $args = array() ){
global $custom_path;
global $game;
if($custom_path == 'game'){ // Check if real page name is "game"
echo '<h3>Current game is: '.$game->title.'</h3>';
echo '<p>This game have '.$game->upvote.' likes</p>';
} else {
echo 'This widget only work on game page';
}
}
public function form( $instance = array() ){
//
}
}
register_widget( 'widget_sample' );
don’t forget to put “global” type on global variable.
Result:
data:image/s3,"s3://crabby-images/68371/68371950baa73fe49042ccd944130101a1acceb5" alt=""
Advanced
Create a new Widget placement
Put code below inside custom.php
register_sidebar(array(
'name' => 'New Placement',
'id' => 'new-placement',
'description' => 'Sample Placement.',
));
Result:
data:image/s3,"s3://crabby-images/b16b5/b16b5d4ac313583512f0d1f03fef89cf3f5c0f32" alt=""
Now you can put widgets on your new placement
Then put this code on your theme code to show the widget placement:
<?php widget_aside('new-placement') ?>