summaryrefslogtreecommitdiff
path: root/modules/latestupdates
diff options
context:
space:
mode:
authorTristan Zur <tzur@webserver.ccwn.org>2015-06-20 23:56:17 +0200
committerTristan Zur <tzur@webserver.ccwn.org>2015-06-20 23:56:17 +0200
commit18a1d682ff18ee69d5c252b013a6a6935cd9b5fe (patch)
treeb1da62c8b7d03341a7b74b3fbb533e6391950be0 /modules/latestupdates
parentb69c03794f80aa811f0613cf4b802619e7ecdbdd (diff)
New modules added
Diffstat (limited to 'modules/latestupdates')
-rw-r--r--modules/latestupdates/controllers/latestupdates.php596
-rw-r--r--modules/latestupdates/css/latestupdates_jcarousel.css95
-rw-r--r--modules/latestupdates/helpers/latestupdates_block.php52
-rw-r--r--modules/latestupdates/helpers/latestupdates_event.php29
-rw-r--r--modules/latestupdates/helpers/latestupdates_theme.php27
-rw-r--r--modules/latestupdates/images/imageNavLeft.gifbin0 -> 538 bytes
-rw-r--r--modules/latestupdates/images/imageNavLeftHover.gifbin0 -> 615 bytes
-rw-r--r--modules/latestupdates/images/imageNavRight.gifbin0 -> 535 bytes
-rw-r--r--modules/latestupdates/images/imageNavRightHover.gifbin0 -> 613 bytes
-rw-r--r--modules/latestupdates/js/jcarousellite_1.0.1.js341
-rw-r--r--modules/latestupdates/module.info7
-rw-r--r--modules/latestupdates/views/latestupdates_block.html.php10
-rw-r--r--modules/latestupdates/views/latestupdates_user_profile_carousel.html.php37
-rw-r--r--modules/latestupdates/views/latestupdates_user_profile_info.html.php14
14 files changed, 1208 insertions, 0 deletions
diff --git a/modules/latestupdates/controllers/latestupdates.php b/modules/latestupdates/controllers/latestupdates.php
new file mode 100644
index 0000000..fb9a8f2
--- /dev/null
+++ b/modules/latestupdates/controllers/latestupdates.php
@@ -0,0 +1,596 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2013 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class latestupdates_Controller extends Controller {
+ public function user_profiles($str_display_type, $user_id) {
+ // Make sure user_id is valid, throw a 404 error if its not.
+ $current_user = ORM::factory("user", $user_id);
+ if (!$current_user->loaded()) {
+ throw new Kohana_404_Exception();
+ }
+
+ // Grab the first 10 items for the specified display type.
+ // Default to "popular" if display type is invalid.
+ $template = new View("latestupdates_user_profile_carousel.html");
+ $template->items = latestupdates_Controller::items($str_display_type, $user_id, 10);
+
+ // Figure out the text for the "View more" link.
+ if ($str_display_type == "recent") {
+ $template->str_view_more_title = t("View all recent uploads");
+ } elseif ($str_display_type == "albums") {
+ $template->str_view_more_title = t("View all recent albums");
+ } else {
+ $template->str_view_more_title = t("View more popular uploads");
+ }
+
+ // Set up a "View more" url.
+ $template->str_view_more_url = url::site("latestupdates/users/{$str_display_type}/{$user_id}");
+
+ // Display the page.
+ print $template;
+
+ // Make item links in the carousel load as virtual albums for the view type instead of the regular album.
+ item::set_display_context_callback("latestupdates_Controller::get_display_context",
+ $str_display_type, $user_id);
+ return ;
+ }
+
+ public function users($str_display_type, $user_id) {
+ // Generate a dynamic page with items uploaded by a specific user ($user_id).
+
+ // Make sure user_id is valid.
+ $current_user = ORM::factory("user", $user_id);
+ if (!$current_user->loaded()) {
+ throw new Kohana_404_Exception();
+ }
+
+ // Figure out how many items to display on each page.
+ $page_size = module::get_var("gallery", "page_size", 9);
+
+ // Figure out which page # the visitor is on and
+ // don't allow the visitor to go below page 1.
+ $page = Input::instance()->get("page", 1);
+ if ($page < 1) {
+ url::redirect("latestupdates/users/{$str_display_type}/{$user_id}");
+ }
+
+ // If this page was reached from a breadcrumb, figure out what page to load from the show id.
+ $show = Input::instance()->get("show");
+ if ($show) {
+ $child = ORM::factory("item", $show);
+ $index = latestupdates_Controller::_get_position($child, $str_display_type, $user_id);
+ if ($index) {
+ $page = ceil($index / $page_size);
+ if ($page == 1) {
+ url::redirect("latestupdates/users/{$str_display_type}/{$user_id}");
+ } else {
+ url::redirect("latestupdates/users/{$str_display_type}/{$user_id}?page=$page");
+ }
+ }
+ }
+
+ // First item to display.
+ $offset = ($page - 1) * $page_size;
+
+ // Determine the total number of items,
+ // for page numbering purposes.
+ $count = latestupdates_Controller::items_count($str_display_type, $user_id);
+
+ // Figure out what the highest page number is.
+ $max_pages = ceil($count / $page_size);
+
+ // Don't let the visitor go past the last page.
+ if ($max_pages && $page > $max_pages) {
+ url::redirect("latestupdates/users/{$str_display_type}/{$user_id}?page=$max_pages");
+ }
+
+ // Figure out which items to display on this page.
+ $children = latestupdates_Controller::items($str_display_type, $user_id, $page_size, $offset);
+
+ // Figure out the page title.
+ $str_page_title = "";
+ if ($str_display_type == "recent") {
+ $str_page_title = t("Recent Uploads");
+ } elseif ($str_display_type == "albums") {
+ $str_page_title = t("Recent Albums");
+ } else {
+ $str_page_title = t("Most Viewed");
+ }
+
+ // Set up the previous and next page buttons.
+ if ($page > 1) {
+ $previous_page = $page - 1;
+ $view->previous_page_link = url::site("latestupdates/users/{$str_display_type}/{$user_id}?page={$previous_page}");
+ }
+ if ($page < $max_pages) {
+ $next_page = $page + 1;
+ $view->next_page_link = url::site("latestupdates/users/{$str_display_type}/{$user_id}?page={$next_page}");
+ }
+
+ // Set up and display the actual page.
+ $root = item::root();
+ $template = new Theme_View("page.html", "collection", "LatestUpdates");
+ $template->page_title = t("Gallery :: Latest Updates");
+ $template->set_global(
+ array("page" => $page,
+ "max_pages" => $max_pages,
+ "page_size" => $page_size,
+ "children" => $children,
+ "breadcrumbs" => array(
+ Breadcrumb::instance($root->title, $root->url())->set_first(),
+ Breadcrumb::instance(t("User profile: %name", array("name" => $current_user->display_name())),
+ url::site("user_profile/show/{$user_id}")),
+ Breadcrumb::instance($str_page_title,
+ url::site("latestupdates/users/{$str_display_type}/{$user_id}"))->set_last()),
+ "children_count" => $count));
+ $template->content = new View("dynamic.html");
+ $template->content->title = $str_page_title;
+
+ // Display the page.
+ print $template;
+
+ // Set up the callback so links within the photo page will lead to photos within the virtual album
+ // instead of the actual album.
+ item::set_display_context_callback("latestupdates_Controller::get_display_context",
+ $str_display_type, $user_id);
+ }
+
+ public function albums($id) {
+ // Figure out how many items to display on each page.
+ $page_size = module::get_var("gallery", "page_size", 9);
+
+ // Load the parent album.
+ $item = ORM::factory("item", $id);
+
+ // Figure out which page # the visitor is on and
+ // don't allow the visitor to go below page 1.
+ $page = Input::instance()->get("page", 1);
+ if ($page < 1) {
+ url::redirect("latestupdates/albums/{$item->id}");
+ }
+
+ // If this page was reached from a breadcrumb, figure out what page to load from the show id.
+ $show = Input::instance()->get("show");
+ if ($show) {
+ $child = ORM::factory("item", $show);
+ $index = latestupdates_Controller::_get_position($child, "descendants", $item->id);
+ if ($index) {
+ $page = ceil($index / $page_size);
+ if ($page == 1) {
+ url::redirect("latestupdates/albums/{$item->id}");
+ } else {
+ url::redirect("latestupdates/albums/{$item->id}?page=$page");
+ }
+ }
+ }
+
+ // First item to display.
+ $offset = ($page - 1) * $page_size;
+
+ // Determine the total number of items,
+ // for page numbering purposes.
+ $count = latestupdates_Controller::items_count("descendants", $item->id);
+
+ // Figure out what the highest page number is.
+ $max_pages = ceil($count / $page_size);
+
+ // Don't let the visitor go past the last page.
+ if ($max_pages && $page > $max_pages) {
+ url::redirect("latestupdates/albums/{$item->id}?page=$max_pages");
+ }
+
+ // Figure out which items to display on this page.
+ $children = latestupdates_Controller::items("descendants", $item->id, $page_size, $offset);
+
+ // Set up the previous and next page buttons.
+ if ($page > 1) {
+ $previous_page = $page - 1;
+ $view->previous_page_link = url::site("latestupdates/albums/{$item->id}?page={$previous_page}");
+ }
+ if ($page < $max_pages) {
+ $next_page = $page + 1;
+ $view->next_page_link = url::site("latestupdates/albums/{$item->id}?page={$next_page}");
+ }
+
+ // Set up breadcrumbs.
+ $breadcrumbs = array();
+ $counter = 0;
+ $breadcrumbs[] = Breadcrumb::instance(t("Recent Uploads"), url::site("latestupdates/albums/{$item->id}"))->set_last();
+ $parent_item = $item;
+ while ($parent_item->id != 1) {
+ $breadcrumbs[] = Breadcrumb::instance($parent_item->title, $parent_item->url());
+ $parent_item = ORM::factory("item", $parent_item->parent_id);
+ }
+ $breadcrumbs[] = Breadcrumb::instance($parent_item->title, $parent_item->url())->set_first();
+ $breadcrumbs = array_reverse($breadcrumbs, true);
+
+ // Set up and display the actual page.
+ $root = item::root();
+ $template = new Theme_View("page.html", "collection", "LatestUpdates");
+ $template->page_title = t("Gallery :: Latest Updates");
+ $template->set_global(
+ array("page" => $page,
+ "max_pages" => $max_pages,
+ "page_size" => $page_size,
+ "children" => $children,
+ "breadcrumbs" => $breadcrumbs,
+ "children_count" => $count));
+ $template->content = new View("dynamic.html");
+ $template->content->title = t("Recent Uploads");
+
+ // Display the page.
+ print $template;
+
+ // Set up the callback so links within the photo page will lead to photos within the virtual album
+ // instead of the actual album.
+ item::set_display_context_callback("latestupdates_Controller::get_display_context",
+ "descendants", $item->id);
+ }
+
+ public function updates() {
+ // Figure out how many items to display on each page.
+ $page_size = module::get_var("gallery", "page_size", 9);
+
+ // Figure out which page # the visitor is on and
+ // don't allow the visitor to go below page 1.
+ $page = Input::instance()->get("page", 1);
+ if ($page < 1) {
+ url::redirect("latestupdates/updates");
+ }
+
+ // If this page was reached from a breadcrumb, figure out what page to load from the show id.
+ $show = Input::instance()->get("show");
+ if ($show) {
+ $child = ORM::factory("item", $show);
+ $index = latestupdates_Controller::_get_position($child, "recent", 0);
+ if ($index) {
+ $page = ceil($index / $page_size);
+ if ($page == 1) {
+ url::redirect("latestupdates/updates");
+ } else {
+ url::redirect("latestupdates/updates?page=$page");
+ }
+ }
+ }
+
+ // First item to display.
+ $offset = ($page - 1) * $page_size;
+
+ // Determine the total number of items,
+ // for page numbering purposes.
+ $count = latestupdates_Controller::items_count("recent", 0);
+
+ // Figure out what the highest page number is.
+ $max_pages = ceil($count / $page_size);
+
+ // Don't let the visitor go past the last page.
+ if ($max_pages && $page > $max_pages) {
+ url::redirect("latestupdates/updates?page=$max_pages");
+ }
+
+ // Figure out which items to display on this page.
+ $items = latestupdates_Controller::items("recent", 0, $page_size, $offset);
+
+ // Set up the previous and next page buttons.
+ if ($page > 1) {
+ $previous_page = $page - 1;
+ $view->previous_page_link = url::site("latestupdates/updates?page={$previous_page}");
+ }
+ if ($page < $max_pages) {
+ $next_page = $page + 1;
+ $view->next_page_link = url::site("latestupdates/updates?page={$next_page}");
+ }
+
+ // Set up and display the actual page.
+ $root = item::root();
+ $template = new Theme_View("page.html", "collection", "LatestUpdates");
+ $template->page_title = t("Gallery :: Latest Updates");
+ $template->set_global(
+ array("page" => $page,
+ "max_pages" => $max_pages,
+ "page_size" => $page_size,
+ "children" => $items,
+ "breadcrumbs" => array(
+ Breadcrumb::instance($root->title, $root->url())->set_first(),
+ Breadcrumb::instance(t("Recent Uploads"),
+ url::site("latestupdates/updates"))->set_last()),
+ "children_count" => $count));
+ $template->content = new View("dynamic.html");
+ $template->content->title = t("Recent Uploads");
+
+ // Display the page.
+ print $template;
+
+ // Set up the callback so links within the photo page will lead to photos within the virtual album
+ // instead of the actual album.
+ item::set_display_context_callback("latestupdates_Controller::get_display_context",
+ "recent", 0);
+ }
+
+ static function get_display_context($item, $str_display_type, $user_id) {
+ // Set up display elements on the photo page to link to the virtual album.
+ // Valid $str_display_type values are popular, recent, albums and descendants.
+ // $user_id can be set to "0" to search site wide.
+ // For "descendants", $user_id should be the album id #.
+
+ // Figure out page title.
+ $str_page_title = "";
+ if ($str_display_type == "recent") {
+ $str_page_title = t("Recent Uploads");
+ } elseif ($str_display_type == "albums") {
+ $str_page_title = t("Recent Albums");
+ } elseif ($str_display_type == "descendants") {
+ $str_page_title = t("Recent Uploads");
+ } else {
+ $str_page_title = t("Most Viewed");
+ }
+
+ // Figure out item position.
+ $position = latestupdates_Controller::_get_position($item, $str_display_type, $user_id);
+
+ // Figure out which items are the previous and next items with the virtual album.
+ if ($position > 1) {
+ list ($previous_item, $ignore, $next_item) =
+ latestupdates_Controller::items($str_display_type, $user_id, 3, $position - 2);
+ } else {
+ $previous_item = null;
+ list ($next_item) = latestupdates_Controller::items($str_display_type, $user_id, 1, $position);
+ }
+
+ // Figure out total number of items (excluding albums).
+ $count = latestupdates_Controller::items_count($str_display_type, $user_id);
+
+ // Set up breadcrumbs.
+ $root = item::root();
+ $breadcrumbs = array();
+ if ($user_id == 0) {
+ $breadcrumbs[0] = Breadcrumb::instance($root->title, $root->url())->set_first();
+ $breadcrumbs[1] = Breadcrumb::instance($str_page_title,
+ url::site("latestupdates/updates?show={$item->id}"));
+ $breadcrumbs[2] = Breadcrumb::instance($item->title, $item->url())->set_last();
+ } else {
+ if ($str_display_type == "descendants") {
+ $counter = 0;
+ $breadcrumbs[] = Breadcrumb::instance($item->title, $item->url())->set_last();
+ $breadcrumbs[] = Breadcrumb::instance(t("Recent Uploads"), url::site("latestupdates/albums/{$user_id}?show={$item->id}"));
+ $parent_item = ORM::factory("item", $user_id);
+ while ($parent_item->id != 1) {
+ $breadcrumbs[] = Breadcrumb::instance($parent_item->title, $parent_item->url());
+ $parent_item = ORM::factory("item", $parent_item->parent_id);
+ }
+ $breadcrumbs[] = Breadcrumb::instance($parent_item->title, $parent_item->url())->set_first();
+ $breadcrumbs = array_reverse($breadcrumbs, true);
+ } else {
+ $current_user = ORM::factory("user", $user_id);
+ $breadcrumbs[0] = Breadcrumb::instance($root->title, $root->url())->set_first();
+ $breadcrumbs[1] = Breadcrumb::instance(t("User profile: %name", array("name" => $current_user->display_name())),
+ url::site("user_profile/show/{$user_id}"));
+ $breadcrumbs[2] = Breadcrumb::instance($str_page_title,
+ url::site("latestupdates/users/{$str_display_type}/{$user_id}?show={$item->id}"));
+ $breadcrumbs[3] = Breadcrumb::instance($item->title, $item->url())->set_last();
+ }
+ }
+
+ // Return the display elements.
+ return array("position" => $position,
+ "previous_item" => $previous_item,
+ "next_item" => $next_item,
+ "sibling_count" => $count,
+ "siblings_callback" => array("latestupdates_Controller::items", array($str_display_type, $user_id)),
+ "breadcrumbs" => $breadcrumbs
+ );
+ }
+
+ static function items_count($str_display_type, $user_id) {
+ // Figure out the total number of items.
+ // Valid $str_display_type values are popular, recent, albums and descendants.
+ // $user_id can be set to "0" to search site wide.
+ // For "descendants", $user_id should be the album id #.
+
+ // If $str_display_type is albums, then we only want albums.
+ // If it's not, then we want everything except albums.
+ if ($str_display_type == "albums") {
+ // This is only used for user profiles, so we always want
+ // results from a specific user.
+ $count = ORM::factory("item")
+ ->viewable()
+ ->where("type", "=", "album")
+ ->where("owner_id", "=", $user_id)
+ ->count_all();
+ } else {
+
+ // If $user_id is not 0 we only want results from a specific user,
+ // Or else we want results from any user.
+ if ($user_id == 0) {
+ $count = ORM::factory("item")
+ ->viewable()
+ ->where("type", "!=", "album")
+ ->count_all();
+ } else {
+
+ // If type is descendants, then user_id is actually an item id#.
+ if ($str_display_type == "descendants") {
+ $item = ORM::factory("item", $user_id);
+ $count = $item
+ ->viewable()
+ ->where("type", "!=", "album")
+ ->order_by("created", "DESC")
+ ->descendants_count();
+ } else {
+ $count = ORM::factory("item")
+ ->viewable()
+ ->where("type", "!=", "album")
+ ->where("owner_id", "=", $user_id)
+ ->count_all();
+ }
+ }
+ }
+
+ return $count;
+ }
+
+ static function items($str_display_type, $user_id, $limit=null, $offset=null) {
+ // Query the database for a list of items to display in the virtual album.
+ // Valid $str_display_type values are popular, recent, albums and descendants.
+ // $user_id can be set to "0" to search site wide.
+ // For "descendants", $user_id should be the album id #.
+
+ // Figure out search parameters based on $str_display_type.
+ $str_where = array();
+ $str_orderby_field = "";
+ if ($str_display_type == "recent") {
+ $str_where = array(array("type", "!=", "album"));
+ $str_orderby_field = "created";
+ } elseif ($str_display_type == "albums") {
+ $str_where = array(array("type", "=", "album"));
+ $str_orderby_field = "created";
+ } else {
+ $str_where = array(array("type", "!=", "album"));
+ $str_orderby_field = "view_count";
+ }
+
+ // Search the database for matching items.
+
+ // Searching for descendants of a parent album is significantly
+ // different from the other query types, so we're doing this one
+ // seperately.
+ if ($str_display_type == "descendants") {
+ $item = ORM::factory("item", $user_id);
+ return $item
+ ->viewable()
+ ->where("type", "!=", "album")
+ ->order_by("created", "DESC")
+ ->descendants($limit, $offset);
+ }
+
+ // If $user_id is greater then 0, limit results
+ // to a specific user.
+ if ($user_id == 0) {
+ return ORM::factory("item")
+ ->viewable()
+ ->merge_where($str_where)
+ ->order_by($str_orderby_field, "DESC")
+ ->find_all($limit, $offset);
+ } else {
+ return ORM::factory("item")
+ ->viewable()
+ ->merge_where($str_where)
+ ->where("owner_id", "=", $user_id)
+ ->order_by($str_orderby_field, "DESC")
+ ->find_all($limit, $offset);
+ }
+ }
+
+ private function _get_position($item, $str_display_type, $user_id) {
+ // Figure out the item's position within the virtual album.
+ // Valid $str_display_type values are popular, recent, albums and descendants.
+ // $user_id can be set to "0" to search site wide.
+ // For "descendants", $user_id should be the album id #.
+
+ // Figure out search conditions.
+ $str_where = array();
+ $str_orderby_field = "";
+ if ($str_display_type == "recent") {
+ $str_where = array(array("type", "!=", "album"));
+ $str_orderby_field = "created";
+ } elseif ($str_display_type == "albums") {
+ $str_where = array(array("type", "=", "album"));
+ $str_orderby_field = "created";
+ } else {
+ $str_where = array(array("type", "!=", "album"));
+ $str_orderby_field = "view_count";
+ }
+
+ // Count the number of records that have a higher orderby_field value then
+ // the item we're looking for.
+ $position = 0;
+ if ($user_id == 0) {
+ $position = ORM::factory("item")
+ ->viewable()
+ ->merge_where($str_where)
+ ->where($str_orderby_field, ">", $item->$str_orderby_field)
+ ->order_by($str_orderby_field, "DESC")
+ ->count_all();
+ } else {
+ if ($str_display_type == "descendants") {
+ $album_item = ORM::factory("item", $user_id);
+ $position = $album_item
+ ->viewable()
+ ->where("type", "!=", "album")
+ ->where("created", ">", $item->created)
+ ->order_by("created", "DESC")
+ ->descendants_count();
+ } else {
+ $position = ORM::factory("item")
+ ->viewable()
+ ->where("owner_id", "=", $user_id)
+ ->merge_where($str_where)
+ ->where($str_orderby_field, ">", $item->$str_orderby_field)
+ ->order_by($str_orderby_field, "DESC")
+ ->count_all();
+ }
+ }
+
+ // Set up a db query for all records with the same orderby field value
+ // as the item we're looking for.
+ $items = ORM::factory("item");
+ if ($user_id == 0) {
+ $items->viewable()
+ ->merge_where($str_where)
+ ->where($str_orderby_field, "=", $item->$str_orderby_field)
+ ->order_by($str_orderby_field, "DESC");
+ } else {
+ if ($str_display_type == "descendants") {
+ $item_album = ORM::factory("item", $user_id);
+ $items = $item_album
+ ->viewable()
+ ->where("type", "!=", "album")
+ ->where("created", "=", $item->created)
+ ->order_by("created", "DESC");
+ } else {
+ $items->viewable()
+ ->where("owner_id", "=", $user_id)
+ ->merge_where($str_where)
+ ->where($str_orderby_field, "=", $item->$str_orderby_field)
+ ->order_by($str_orderby_field, "DESC");
+ }
+ }
+
+ // Loop through each remaining match, increasing position by 1 each time
+ // until we find a match.
+ if ($str_display_type == "descendants") {
+ foreach ($items->descendants() as $row) {
+ $position++;
+ if ($row->id == $item->id) {
+ break;
+ }
+ }
+ } else {
+ foreach ($items->find_all() as $row) {
+ $position++;
+ if ($row->id == $item->id) {
+ break;
+ }
+ }
+ }
+
+ // Return the result.
+ return $position;
+ }
+}
diff --git a/modules/latestupdates/css/latestupdates_jcarousel.css b/modules/latestupdates/css/latestupdates_jcarousel.css
new file mode 100644
index 0000000..f123143
--- /dev/null
+++ b/modules/latestupdates/css/latestupdates_jcarousel.css
@@ -0,0 +1,95 @@
+#jCarouselLite .carousel {
+ padding: 10px 0 0 0;
+ margin: 0 0 20px 10px;
+ position: relative;
+}
+
+#jCarouselLite .digg {
+ position: absolute;
+ left: 610px;
+ top: 110px;
+}
+
+#jCarouselLite .main {
+ margin-left: 0px;
+}
+
+#jCarouselLite .demo em {
+ color: #FF3300;
+ font-weight: bold;
+ font-size: 60%;
+ font-style: normal;
+}
+
+#jCarouselLite .carousel a.prev, #jCarouselLite .carousel a.next {
+ display: block;
+ float: left;
+ width: 30px;
+ height: 90px;
+ text-decoration: none;
+ background: url("../images/imageNavLeft.gif") left 60px no-repeat;
+}
+
+#jCarouselLite .carousel a.next {
+ background: url("../images/imageNavRight.gif") right 60px no-repeat;
+}
+
+#jCarouselLite .carousel a.next:hover {
+ background-image: url("../images/imageNavRightHover.gif");
+}
+
+#jCarouselLite .carousel a.prev:hover {
+ background-image: url("../images/imageNavLeftHover.gif");
+}
+
+#jCarouselLite .carousel a:hover, #jCarouselLite .carousel a:active {
+ border: none;
+ outline: none;
+}
+
+#jCarouselLite .carousel .jCarouselLite {
+ border: 1px solid black;
+ float: left;
+ background-color: #dfdfdf;
+
+ /* Needed for rendering without flicker */
+ position: relative;
+ visibility: hidden;
+ left: -5000px;
+}
+
+#jCarouselLite .carousel ul {
+ margin: 0;
+}
+
+#jCarouselLite .carousel li img,
+#jCarouselLite .carousel li p {
+ background-color: #fff;
+ margin: 10px;
+}
+
+#jCarouselLite .widget img {
+ cursor: pointer;
+}
+
+#jCarouselLite .mid {
+ margin-left: 80px;
+ width: 400px;
+ height: 300px;
+}
+
+#jCarouselLite .vertical {
+ margin-left: 90px;
+}
+
+#jCarouselLite .vertical .jCarouselLite { /* so that in IE 6, the carousel div doesnt expand to fill the space */
+ width: 90px;
+}
+
+#jCarouselLite .imageSlider li img,
+#jCarouselLite .imageSlider li p,
+#jCarouselLite .imageSliderExt li img ,
+#jCarouselLite .imageSliderExt li p {
+ width: 400px;
+ height: 300px;
+}
diff --git a/modules/latestupdates/helpers/latestupdates_block.php b/modules/latestupdates/helpers/latestupdates_block.php
new file mode 100644
index 0000000..b15b90f
--- /dev/null
+++ b/modules/latestupdates/helpers/latestupdates_block.php
@@ -0,0 +1,52 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2013 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class latestupdates_block_Core {
+ static function get_site_list() {
+ return array("latestupdates" => t("Latest Updates"));
+ }
+
+ static function get($block_id, $theme) {
+ $block = "";
+
+ switch ($block_id) {
+ case "latestupdates":
+
+ // Make a new sidebar block.
+ $block = new Block();
+ $block->css_id = "g-latest-updates";
+ $block->title = t("Latest Updates");
+ $block->content = new View("latestupdates_block.html");
+
+ if (!$theme->item()) {
+ $block->content->update_links = array(
+ "Entire Gallery" => url::site("latestupdates/updates"));
+ } else {
+ // Determine the ID# of the current album.
+ $albumID = $theme->item->is_album() ? $theme->item->id : $theme->item->parent_id;
+ $block->content->update_links = array(
+ "Entire Gallery" => url::site("latestupdates/updates"),
+ "This Album" => url::site("latestupdates/albums/$albumID")
+ );
+ }
+ break;
+ }
+ return $block;
+ }
+}
diff --git a/modules/latestupdates/helpers/latestupdates_event.php b/modules/latestupdates/helpers/latestupdates_event.php
new file mode 100644
index 0000000..3809933
--- /dev/null
+++ b/modules/latestupdates/helpers/latestupdates_event.php
@@ -0,0 +1,29 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2013 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+
+class latestupdates_event_Core {
+ static function show_user_profile($data) {
+ // Display links on the user profile pages for recent photos/albums
+ // and most popular photos from the specified user.
+ $v = new View("latestupdates_user_profile_info.html");
+ $v->user_id = $data->user->id;
+ $data->content[] = (object) array("title" => t("Latest Updates"), "view" => $v);
+ }
+}
diff --git a/modules/latestupdates/helpers/latestupdates_theme.php b/modules/latestupdates/helpers/latestupdates_theme.php
new file mode 100644
index 0000000..e6423a8
--- /dev/null
+++ b/modules/latestupdates/helpers/latestupdates_theme.php
@@ -0,0 +1,27 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2013 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+
+class latestupdates_theme_Core {
+ static function head($theme) {
+ // Load CSS and JS for jCarouselLite.
+ return $theme->script("jcarousellite_1.0.1.js") .
+ $theme->css("latestupdates_jcarousel.css");
+ }
+}
diff --git a/modules/latestupdates/images/imageNavLeft.gif b/modules/latestupdates/images/imageNavLeft.gif
new file mode 100644
index 0000000..9c0e5af
--- /dev/null
+++ b/modules/latestupdates/images/imageNavLeft.gif
Binary files differ
diff --git a/modules/latestupdates/images/imageNavLeftHover.gif b/modules/latestupdates/images/imageNavLeftHover.gif
new file mode 100644
index 0000000..0945b9e
--- /dev/null
+++ b/modules/latestupdates/images/imageNavLeftHover.gif
Binary files differ
diff --git a/modules/latestupdates/images/imageNavRight.gif b/modules/latestupdates/images/imageNavRight.gif
new file mode 100644
index 0000000..ad4bb00
--- /dev/null
+++ b/modules/latestupdates/images/imageNavRight.gif
Binary files differ
diff --git a/modules/latestupdates/images/imageNavRightHover.gif b/modules/latestupdates/images/imageNavRightHover.gif
new file mode 100644
index 0000000..a5abcc9
--- /dev/null
+++ b/modules/latestupdates/images/imageNavRightHover.gif
Binary files differ
diff --git a/modules/latestupdates/js/jcarousellite_1.0.1.js b/modules/latestupdates/js/jcarousellite_1.0.1.js
new file mode 100644
index 0000000..07b82a6
--- /dev/null
+++ b/modules/latestupdates/js/jcarousellite_1.0.1.js
@@ -0,0 +1,341 @@
+/**
+ * jCarouselLite - jQuery plugin to navigate images/any content in a carousel style widget.
+ * @requires jQuery v1.2 or above
+ *
+ * http://gmarwaha.com/jquery/jcarousellite/
+ *
+ * Copyright (c) 2007 Ganeshji Marwaha (gmarwaha.com)
+ * Dual licensed under the MIT and GPL licenses:
+ * http://www.opensource.org/licenses/mit-license.php
+ * http://www.gnu.org/licenses/gpl.html
+ *
+ * Version: 1.0.1
+ * Note: Requires jquery 1.2 or above from version 1.0.1
+ */
+
+/**
+ * Creates a carousel-style navigation widget for images/any-content from a simple HTML markup.
+ *
+ * The HTML markup that is used to build the carousel can be as simple as...
+ *
+ * <div class="carousel">
+ * <ul>
+ * <li><img src="image/1.jpg" alt="1"></li>
+ * <li><img src="image/2.jpg" alt="2"></li>
+ * <li><img src="image/3.jpg" alt="3"></li>
+ * </ul>
+ * </div>
+ *
+ * As you can see, this snippet is nothing but a simple div containing an unordered list of images.
+ * You don't need any special "class" attribute, or a special "css" file for this plugin.
+ * I am using a class attribute just for the sake of explanation here.
+ *
+ * To navigate the elements of the carousel, you need some kind of navigation buttons.
+ * For example, you will need a "previous" button to go backward, and a "next" button to go forward.
+ * This need not be part of the carousel "div" itself. It can be any element in your page.
+ * Lets assume that the following elements in your document can be used as next, and prev buttons...
+ *
+ * <button class="prev">&lt;&lt;</button>
+ * <button class="next">&gt;&gt;</button>
+ *
+ * Now, all you need to do is call the carousel component on the div element that represents it, and pass in the
+ * navigation buttons as options.
+ *
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev"
+ * });
+ *
+ * That's it, you would have now converted your raw div, into a magnificient carousel.
+ *
+ * There are quite a few other options that you can use to customize it though.
+ * Each will be explained with an example below.
+ *
+ * @param an options object - You can specify all the options shown below as an options object param.
+ *
+ * @option btnPrev, btnNext : string - no defaults
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev"
+ * });
+ * @desc Creates a basic carousel. Clicking "btnPrev" navigates backwards and "btnNext" navigates forward.
+ *
+ * @option btnGo - array - no defaults
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * btnGo: [".0", ".1", ".2"]
+ * });
+ * @desc If you don't want next and previous buttons for navigation, instead you prefer custom navigation based on
+ * the item number within the carousel, you can use this option. Just supply an array of selectors for each element
+ * in the carousel. The index of the array represents the index of the element. What i mean is, if the
+ * first element in the array is ".0", it means that when the element represented by ".0" is clicked, the carousel
+ * will slide to the first element and so on and so forth. This feature is very powerful. For example, i made a tabbed
+ * interface out of it by making my navigation elements styled like tabs in css. As the carousel is capable of holding
+ * any content, not just images, you can have a very simple tabbed navigation in minutes without using any other plugin.
+ * The best part is that, the tab will "slide" based on the provided effect. :-)
+ *
+ * @option mouseWheel : boolean - default is false
+ * @example
+ * $(".carousel").jCarouselLite({
+ * mouseWheel: true
+ * });
+ * @desc The carousel can also be navigated using the mouse wheel interface of a scroll mouse instead of using buttons.
+ * To get this feature working, you have to do 2 things. First, you have to include the mouse-wheel plugin from brandon.
+ * Second, you will have to set the option "mouseWheel" to true. That's it, now you will be able to navigate your carousel
+ * using the mouse wheel. Using buttons and mouseWheel or not mutually exclusive. You can still have buttons for navigation
+ * as well. They complement each other. To use both together, just supply the options required for both as shown below.
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * mouseWheel: true
+ * });
+ *
+ * @option auto : number - default is null, meaning autoscroll is disabled by default
+ * @example
+ * $(".carousel").jCarouselLite({
+ * auto: 800,
+ * speed: 500
+ * });
+ * @desc You can make your carousel auto-navigate itself by specfying a millisecond value in this option.
+ * The value you specify is the amount of time between 2 slides. The default is null, and that disables auto scrolling.
+ * Specify this value and magically your carousel will start auto scrolling.
+ *
+ * @option speed : number - 200 is default
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * speed: 800
+ * });
+ * @desc Specifying a speed will slow-down or speed-up the sliding speed of your carousel. Try it out with
+ * different speeds like 800, 600, 1500 etc. Providing 0, will remove the slide effect.
+ *
+ * @option easing : string - no easing effects by default.
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * easing: "bounceout"
+ * });
+ * @desc You can specify any easing effect. Note: You need easing plugin for that. Once specified,
+ * the carousel will slide based on the provided easing effect.
+ *
+ * @option vertical : boolean - default is false
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * vertical: true
+ * });
+ * @desc Determines the direction of the carousel. true, means the carousel will display vertically. The next and
+ * prev buttons will slide the items vertically as well. The default is false, which means that the carousel will
+ * display horizontally. The next and prev items will slide the items from left-right in this case.
+ *
+ * @option circular : boolean - default is true
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * circular: false
+ * });
+ * @desc Setting it to true enables circular navigation. This means, if you click "next" after you reach the last
+ * element, you will automatically slide to the first element and vice versa. If you set circular to false, then
+ * if you click on the "next" button after you reach the last element, you will stay in the last element itself
+ * and similarly for "previous" button and first element.
+ *
+ * @option visible : number - default is 3
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * visible: 4
+ * });
+ * @desc This specifies the number of items visible at all times within the carousel. The default is 3.
+ * You are even free to experiment with real numbers. Eg: "3.5" will have 3 items fully visible and the
+ * last item half visible. This gives you the effect of showing the user that there are more images to the right.
+ *
+ * @option start : number - default is 0
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * start: 2
+ * });
+ * @desc You can specify from which item the carousel should start. Remember, the first item in the carousel
+ * has a start of 0, and so on.
+ *
+ * @option scrool : number - default is 1
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * scroll: 2
+ * });
+ * @desc The number of items that should scroll/slide when you click the next/prev navigation buttons. By
+ * default, only one item is scrolled, but you may set it to any number. Eg: setting it to "2" will scroll
+ * 2 items when you click the next or previous buttons.
+ *
+ * @option beforeStart, afterEnd : function - callbacks
+ * @example
+ * $(".carousel").jCarouselLite({
+ * btnNext: ".next",
+ * btnPrev: ".prev",
+ * beforeStart: function(a) {
+ * alert("Before animation starts:" + a);
+ * },
+ * afterEnd: function(a) {
+ * alert("After animation ends:" + a);
+ * }
+ * });
+ * @desc If you wanted to do some logic in your page before the slide starts and after the slide ends, you can
+ * register these 2 callbacks. The functions will be passed an argument that represents an array of elements that
+ * are visible at the time of callback.
+ *
+ *
+ * @cat Plugins/Image Gallery
+ * @author Ganeshji Marwaha/ganeshread@gmail.com
+ */
+
+(function($) { // Compliant with jquery.noConflict()
+$.fn.jCarouselLite = function(o) {
+ o = $.extend({
+ btnPrev: null,
+ btnNext: null,
+ btnGo: null,
+ mouseWheel: false,
+ auto: null,
+
+ speed: 200,
+ easing: null,
+
+ vertical: false,
+ circular: true,
+ visible: 3,
+ start: 0,
+ scroll: 1,
+
+ beforeStart: null,
+ afterEnd: null
+ }, o || {});
+
+ return this.each(function() { // Returns the element collection. Chainable.
+
+ var running = false, animCss=o.vertical?"top":"left", sizeCss=o.vertical?"height":"width";
+ var div = $(this), ul = $("ul", div), tLi = $("li", ul), tl = tLi.size(), v = o.visible;
+
+ if(o.circular) {
+ ul.prepend(tLi.slice(tl-v-1+1).clone())
+ .append(tLi.slice(0,v).clone());
+ o.start += v;
+ }
+
+ var li = $("li", ul), itemLength = li.size(), curr = o.start;
+ div.css("visibility", "visible");
+
+ li.css({overflow: "hidden", float: o.vertical ? "none" : "left"});
+ ul.css({margin: "0", padding: "0", position: "relative", "list-style-type": "none", "z-index": "1"});
+ div.css({overflow: "hidden", position: "relative", "z-index": "2", left: "0px"});
+
+ var liSize = o.vertical ? height(li) : width(li); // Full li size(incl margin)-Used for animation
+ var ulSize = liSize * itemLength; // size of full ul(total length, not just for the visible items)
+ var divSize = liSize * v; // size of entire div(total length for just the visible items)
+
+ li.css({width: li.width(), height: li.height()});
+ ul.css(sizeCss, ulSize+"px").css(animCss, -(curr*liSize));
+
+ div.css(sizeCss, divSize+"px"); // Width of the DIV. length of visible images
+
+ if(o.btnPrev)
+ $(o.btnPrev).click(function() {
+ return go(curr-o.scroll);
+ });
+
+ if(o.btnNext)
+ $(o.btnNext).click(function() {
+ return go(curr+o.scroll);
+ });
+
+ if(o.btnGo)
+ $.each(o.btnGo, function(i, val) {
+ $(val).click(function() {
+ return go(o.circular ? o.visible+i : i);
+ });
+ });
+
+ if(o.mouseWheel && div.mousewheel)
+ div.mousewheel(function(e, d) {
+ return d>0 ? go(curr-o.scroll) : go(curr+o.scroll);
+ });
+
+ if(o.auto)
+ setInterval(function() {
+ go(curr+o.scroll);
+ }, o.auto+o.speed);
+
+ function vis() {
+ return li.slice(curr).slice(0,v);
+ };
+
+ function go(to) {
+ if(!running) {
+
+ if(o.beforeStart)
+ o.beforeStart.call(this, vis());
+
+ if(o.circular) { // If circular we are in first or last, then goto the other end
+ if(to<=o.start-v-1) { // If first, then goto last
+ ul.css(animCss, -((itemLength-(v*2))*liSize)+"px");
+ // If "scroll" > 1, then the "to" might not be equal to the condition; it can be lesser depending on the number of elements.
+ curr = to==o.start-v-1 ? itemLength-(v*2)-1 : itemLength-(v*2)-o.scroll;
+ } else if(to>=itemLength-v+1) { // If last, then goto first
+ ul.css(animCss, -( (v) * liSize ) + "px" );
+ // If "scroll" > 1, then the "to" might not be equal to the condition; it can be greater depending on the number of elements.
+ curr = to==itemLength-v+1 ? v+1 : v+o.scroll;
+ } else curr = to;
+ } else { // If non-circular and to points to first or last, we just return.
+ if(to<0 || to>itemLength-v) return;
+ else curr = to;
+ } // If neither overrides it, the curr will still be "to" and we can proceed.
+
+ running = true;
+
+ ul.animate(
+ animCss == "left" ? { left: -(curr*liSize) } : { top: -(curr*liSize) } , o.speed, o.easing,
+ function() {
+ if(o.afterEnd)
+ o.afterEnd.call(this, vis());
+ running = false;
+ }
+ );
+ // Disable buttons when the carousel reaches the last/first, and enable when not
+ if(!o.circular) {
+ $(o.btnPrev + "," + o.btnNext).removeClass("disabled");
+ $( (curr-o.scroll<0 && o.btnPrev)
+ ||
+ (curr+o.scroll > itemLength-v && o.btnNext)
+ ||
+ []
+ ).addClass("disabled");
+ }
+
+ }
+ return false;
+ };
+ });
+};
+
+function css(el, prop) {
+ return parseInt($.css(el[0], prop)) || 0;
+};
+function width(el) {
+ return el[0].offsetWidth + css(el, 'marginLeft') + css(el, 'marginRight');
+};
+function height(el) {
+ return el[0].offsetHeight + css(el, 'marginTop') + css(el, 'marginBottom');
+};
+
+})(jQuery); \ No newline at end of file
diff --git a/modules/latestupdates/module.info b/modules/latestupdates/module.info
new file mode 100644
index 0000000..95aba92
--- /dev/null
+++ b/modules/latestupdates/module.info
@@ -0,0 +1,7 @@
+name = "LatestUpdates"
+description = "Display recently uploaded photos and videos."
+version = 1
+author_name = "rWatcher"
+author_url = "http://codex.gallery2.org/User:RWatcher"
+info_url = "http://codex.gallery2.org/Gallery3:Modules:latestupdates"
+discuss_url = "http://gallery.menalto.com/node/88936"
diff --git a/modules/latestupdates/views/latestupdates_block.html.php b/modules/latestupdates/views/latestupdates_block.html.php
new file mode 100644
index 0000000..b1dd907
--- /dev/null
+++ b/modules/latestupdates/views/latestupdates_block.html.php
@@ -0,0 +1,10 @@
+<?php defined("SYSPATH") or die("No direct script access.") ?>
+<ul id="g-update-list">
+<? foreach($update_links as $title => $url): ?>
+ <li style="clear: both;">
+ <a href="<?= $url ?>">
+ <?= t($title) ?>
+ </a>
+ </li>
+<? endforeach ?>
+</ul>
diff --git a/modules/latestupdates/views/latestupdates_user_profile_carousel.html.php b/modules/latestupdates/views/latestupdates_user_profile_carousel.html.php
new file mode 100644
index 0000000..1a3ada2
--- /dev/null
+++ b/modules/latestupdates/views/latestupdates_user_profile_carousel.html.php
@@ -0,0 +1,37 @@
+<?php defined("SYSPATH") or die("No direct script access.") ?>
+<? if (count($items) == 0): ?>
+ <center><?=t("This user hasn't uploaded anything yet."); ?></center>
+<? else: ?>
+<script>
+$(document).ready(function() { setTimeout(LoadCarousel, 100); });
+function LoadCarousel() {
+ $(".main .jCarouselLite").jCarouselLite({
+ btnNext: ".next",
+ btnPrev: ".prev",
+ visible: 4,
+ circular: false
+ });
+}
+</script>
+<div id="jCarouselLite" class="cEnd" style="width: 570px;">
+ <div class="carousel main">
+ <a href="#" class="prev">&nbsp</a>
+ <div class="jCarouselLite">
+ <ul>
+ <? foreach ($items as $photo): ?>
+ <li class="g-item g-photo">
+ <a href="<?= $photo->url() ?>" title="<?= html::purify($photo->title)->for_html_attr() ?>">
+ <img <?= photo::img_dimensions($photo->thumb_width, $photo->thumb_height, 100) ?>
+ src="<?= $photo->thumb_url() ?>" alt="<?= html::purify($photo->title)->for_html_attr() ?>" />
+ </a>
+ </li>
+ <? endforeach ?>
+ </ul>
+ </div>
+ <a href="#" class="next">&nbsp</a>
+ <div class="clear"></div>
+ </div>
+</div>
+<br />
+<div style="width: 510px; text-align: right;"><a href="<?=$str_view_more_url; ?>"><?=$str_view_more_title; ?> >></a></div>
+<? endif; ?>
diff --git a/modules/latestupdates/views/latestupdates_user_profile_info.html.php b/modules/latestupdates/views/latestupdates_user_profile_info.html.php
new file mode 100644
index 0000000..175d137
--- /dev/null
+++ b/modules/latestupdates/views/latestupdates_user_profile_info.html.php
@@ -0,0 +1,14 @@
+<?php defined("SYSPATH") or die("No direct script access.") ?>
+<script>
+ $(function() {
+ $( "#tabs" ).tabs();
+ });
+</script>
+<br />
+<div id="tabs" style="height: 200px">
+ <ul>
+ <li><a class="g-menu-link" href="<?= url::site("latestupdates/user_profiles/popular/{$user_id}") ?>" title="<?= t("Most Viewed") ?>"><?= t("Most Viewed") ?></a></li>
+ <li><a class="g-menu-link" href="<?= url::site("latestupdates/user_profiles/recent/{$user_id}") ?>" title="<?= t("Recent Uploads") ?>"><?= t("Recent Uploads") ?></a></li>
+ <li><a class="g-menu-link" href="<?= url::site("latestupdates/user_profiles/albums/{$user_id}") ?>" title="<?= t("Recent Albums") ?>"><?= t("Recent Albums") ?></a></li>
+ </ul>
+</div>