summaryrefslogtreecommitdiff
path: root/modules/image_block
diff options
context:
space:
mode:
authorTim Almdal <tnalmdal@shaw.ca>2009-09-30 07:31:11 -0700
committerTim Almdal <tnalmdal@shaw.ca>2009-09-30 07:31:12 -0700
commit60d35b89929d9029c794f72d6a9c38b676e282f6 (patch)
tree9239265f275bc9e26dd7ac05678fe134ebff528a /modules/image_block
parent39cd84d86c69090ccf861b9bd2b4758350a47de2 (diff)
Use the block_manager to manage site sidebar panels. Fixes ticket #110.
* Extend block_manager to handle sidebar blocks. get_available has become get_available_admin_blocks, get_list becomes get_admin_list. * Create new functions get_available_site_blocks which will look for gallery_block get_available_site_blocks. * Refactor sidebar_blocks into a separate function and then call block_manager::get_html(site.sidebar). Convert image_block to use block management instead of theme::sidebar_blocks * Change the block_manager api so that the theme is passed into the get method. convert info to the new sidebar block approach * Convert the user module to use the new sidebar block structure. remove the installers for info and image_block modules. * Convert tag and rss modules to the new sidebar framework. reset the version number to 1 for info and image_block modules. * Change the get_html method to ignore empty blocks and change the individual handlers to return an empty string if no block is generated * Add a warning message if no sidebar blocks are active and provide a link to the admin page that configures the sidebar.
Diffstat (limited to 'modules/image_block')
-rw-r--r--modules/image_block/helpers/image_block_block.php (renamed from modules/image_block/helpers/image_block_theme.php)51
1 files changed, 32 insertions, 19 deletions
diff --git a/modules/image_block/helpers/image_block_theme.php b/modules/image_block/helpers/image_block_block.php
index 78138b23..d0402eb6 100644
--- a/modules/image_block/helpers/image_block_theme.php
+++ b/modules/image_block/helpers/image_block_block.php
@@ -17,34 +17,47 @@
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
*/
-class image_block_theme_Core {
- static function sidebar_blocks($theme) {
- $block = new Block();
- $block->css_id = "gImageBlock";
- $block->title = t("Random Image");
- $block->content = new View("image_block_block.html");
+class image_block_block_Core {
+ static function get_site_list() {
+ return array("random_image" => t("Random Image"));
+ }
- $random = ((float)mt_rand()) / (float)mt_getrandmax();
+ static function get($block_id, $theme) {
+ $block = "";
+ switch ($block_id) {
+ case "random_image":
+ $block = new Block();
+ $block->css_id = "gImageBlock";
+ $block->title = t("Random Image");
+ $block->content = new View("image_block_block.html");
- $items = ORM::factory("item")
- ->viewable()
- ->where("type !=", "album")
- ->where("rand_key < ", $random)
- ->orderby(array("rand_key" => "DESC"))
- ->find_all(1);
+ $random = ((float)mt_rand()) / (float)mt_getrandmax();
- if ($items->count() == 0) {
- // Try once more. If this fails, just ditch the block altogether
$items = ORM::factory("item")
->viewable()
->where("type !=", "album")
- ->where("rand_key >= ", $random)
+ ->where("rand_key < ", $random)
->orderby(array("rand_key" => "DESC"))
->find_all(1);
- }
- $block->content->item = $items->current();
+ if ($items->count() == 0) {
+ // Try once more. If this fails, just ditch the block altogether
+ $items = ORM::factory("item")
+ ->viewable()
+ ->where("type !=", "album")
+ ->where("rand_key >= ", $random)
+ ->orderby(array("rand_key" => "DESC"))
+ ->find_all(1);
+ }
+
+ if ($items->count() > 0) {
+ $block->content->item = $items->current();
+ } else {
+ $block = "";
+ }
+ break;
+ }
- return $items->count() == 0 ? "" : $block;
+ return $block;
}
}