From f87e1de3ec0b199a48818f84bdef4cdf34b50244 Mon Sep 17 00:00:00 2001 From: Tim Almdal Date: Thu, 26 Feb 2009 15:02:04 +0000 Subject: Implement a random image block for the side bar. Ticket #13 --- modules/image_block/helpers/image_block_event.php | 27 +++++++++ .../image_block/helpers/image_block_installer.php | 42 ++++++++++++++ modules/image_block/helpers/image_block_theme.php | 64 ++++++++++++++++++++++ modules/image_block/module.info | 3 + .../image_block/views/image_block_block.html.php | 6 ++ 5 files changed, 142 insertions(+) create mode 100644 modules/image_block/helpers/image_block_event.php create mode 100644 modules/image_block/helpers/image_block_installer.php create mode 100644 modules/image_block/helpers/image_block_theme.php create mode 100644 modules/image_block/module.info create mode 100644 modules/image_block/views/image_block_block.html.php (limited to 'modules') diff --git a/modules/image_block/helpers/image_block_event.php b/modules/image_block/helpers/image_block_event.php new file mode 100644 index 00000000..3bcabda1 --- /dev/null +++ b/modules/image_block/helpers/image_block_event.php @@ -0,0 +1,27 @@ +query("UPDATE `items` SET `rand_key` = RAND() WHERE id = {$item->id}"); + Kohana::log("debug", Database::instance()->last_query()); + } + +} diff --git a/modules/image_block/helpers/image_block_installer.php b/modules/image_block/helpers/image_block_installer.php new file mode 100644 index 00000000..6b0ec20b --- /dev/null +++ b/modules/image_block/helpers/image_block_installer.php @@ -0,0 +1,42 @@ +query("ALTER TABLE `items` ADD `rand_key` FLOAT DEFAULT NULL"); + $db->query("UPDATE `items` SET `rand_key` = RAND()"); + $db->query("CREATE INDEX `random_index` ON `items` (rand_key DESC)"); + + module::set_version("image_block", 1); + } + } + + static function uninstall() { + $db = Database::instance(); + // Dropping the column should drop the index as well. + $db->query("ALTER TABLE `items` DROP `rand_key`"); + + module::delete("image_block"); + } +} diff --git a/modules/image_block/helpers/image_block_theme.php b/modules/image_block/helpers/image_block_theme.php new file mode 100644 index 00000000..0a103add --- /dev/null +++ b/modules/image_block/helpers/image_block_theme.php @@ -0,0 +1,64 @@ +viewable() + ->select("COUNT(*) AS C") + ->find(); + if (empty($result->C)) { + return ""; + } + + $block = new Block(); + $block->css_id = "gImageBlock"; + $block->title = t("Random Image"); + $block->content = new View("image_block_block.html"); + + $result = ORM::factory("item") + ->viewable() + ->select("MAX(rand_key) AS max_random") + ->find(); + + $max_rand = $result->max_random; + $random = ((float)mt_rand()) / (float)mt_getrandmax(); + + $items = ORM::factory("item") + ->viewable() + ->where("type !=", "album") + ->where("rand_key < ", $max_rand * $random) + ->orderby(array("rand_key" => "DESC")) + ->find_all(1); + + if ($items->count() == 0) { + $items = ORM::factory("item") + ->viewable() + ->where("type !=", "album") + ->where("rand_key > ", $max_rand * $random) + ->orderby(array("rand_key" => "DESC")) + ->find_all(1); + + } + + $block->content->item = $items->current(); + + return $items->count() == 0 ? "" : $block; + } +} diff --git a/modules/image_block/module.info b/modules/image_block/module.info new file mode 100644 index 00000000..8852d33c --- /dev/null +++ b/modules/image_block/module.info @@ -0,0 +1,3 @@ +name = Image Block +description = Display a random image in the sidebar +version = 1 diff --git a/modules/image_block/views/image_block_block.html.php b/modules/image_block/views/image_block_block.html.php new file mode 100644 index 00000000..87afe4da --- /dev/null +++ b/modules/image_block/views/image_block_block.html.php @@ -0,0 +1,6 @@ + +
+ + thumb_tag(array("class" => "gThumbnail")) ?> + +
-- cgit v1.2.3