Adds blocks of content to a sidebar
PHP JavaScript
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
controllers
forms
helpers
libraries/Blocks
models
views
BlocksPlugin.php
README.md
plugin.ini
plugin.php

README.md

Blocks

Blocks are similar to widgets in WordPress or, you guessed it, blocks in Drupal.

The blocks configuration screen lets you assign blocks according to the URL path. Usually, you will want to assign a block to a page type (e.g., "items") and/or a subpage (e.g., "show"). For a specific page, you can go all the way down to the id. (Plugin developers will recognize that this works from the router: controller/action/id)

To make your theme display blocks, you will need to add the following code to all the files that should display blocks:

This makes the most sense just before the primary div on each page.

== Creating New Blocks ==

Plugin writers can extend the class Blocks_Block_Abstract to create new kinds of blocks.

Blocks must override the render() method, which returns the HTML to display in your new block.

Your plugin must register the blocks with the Blocks plugin on installation. The mechanism is simple. Get and unserialize the 'blocks' option, add the name of your class(es) that extend Blocks_Block_Abstract, and serialize it back into the option. This would make most sense in the hookInstall() method of your plugin. It would be polite to similarly remove them in hookUninstall().

$blocks = unserialize(get_option('blocks'));
$blocks[] = 'MyFunkyBlock';
$blocks[] = 'MyEvenFunkierBlock';
set_option('blocks', serialize($blocks));

Also, follow the pattern of the two blocks in plugin.php.