diff --git a/ext/index/main.php b/ext/index/main.php
index 153795e4..a5ec0721 100644
--- a/ext/index/main.php
+++ b/ext/index/main.php
@@ -1,8 +1,11 @@
theme)) $this->theme = get_theme_object("index", "IndexTheme");
+
if(is_a($event, 'PageRequestEvent') && ($event->page == "index")) {
$search_terms = array();
$page_number = 1;
@@ -14,51 +17,17 @@ class Index extends Extension {
if(isset($_GET['search'])) {
$search_terms = explode(' ', $_GET['search']);
- $query = "search=".url_escape($_GET['search']);
- }
- else {
- $query = null;
}
- global $page;
global $config;
global $database;
$total_pages = $database->count_pages($search_terms);
$count = $config->get_int('index_width') * $config->get_int('index_height');
$images = $database->get_images(($page_number-1)*$count, $count, $search_terms);
-
- if(count($search_terms) == 0) {
- $page_title = $config->get_string('title');
- }
- else {
- $page_title = html_escape($_GET['search']);
- /*
- $page_title = "";
- foreach($search_terms as $term) {
- $u_term = url_escape($term);
- $h_term = html_escape($term);
- $page_title .= "$h_term";
- }
- */
- if(count($images) > 0) {
- $page->set_subheading("Page $page_number / $total_pages");
- }
- }
- if($page_number > 1 || count($search_terms) > 0) {
- // $page_title .= " / $page_number";
- }
- $page->set_title($page_title);
- $page->set_heading($page_title);
- $page->add_block(new Block("Navigation", $this->build_navigation($page_number, $total_pages, $search_terms), "left", 0));
- if(count($images) > 0) {
- $page->add_block(new Block("Images", $this->build_table($images, $query), "main", 10));
- $page->add_block(new Paginator("index", $query, $page_number, $total_pages));
- }
- else {
- $page->add_block(new Block("No Images Found", "No images were found to match the search criteria"));
- }
+ $this->theme->set_page($page_number, $total_pages, $search_terms);
+ $this->theme->display_page($event->page, $page_title, $images);
}
if(is_a($event, 'SetupBuildingEvent')) {
@@ -81,58 +50,6 @@ class Index extends Extension {
$event->config->set_string_from_post("image_tip");
}
}
-// }}}
-// HTML generation {{{
- private function build_navigation($page_number, $total_pages, $search_terms) {
- $prev = $page_number - 1;
- $next = $page_number + 1;
-
- $u_tags = url_escape(implode(" ", $search_terms));
- $query = empty($u_tags) ? null : "search=$u_tags";
-
-
- $h_prev = ($page_number <= 1) ? "Prev" : "Prev";
- $h_index = "Index";
- $h_next = ($page_number >= $total_pages) ? "Next" : "Next";
-
- $h_search_string = count($search_terms) == 0 ? "Search" : html_escape(implode(" ", $search_terms));
- $h_search_link = make_link("index");
- $h_search = "
-
- ";
-
- return "$h_prev | $h_index | $h_next
$h_search";
- }
-
- private function build_table($images, $query) {
- global $config;
-
- $width = $config->get_int('index_width');
- $height = $config->get_int('index_height');
-
- $table = "\n";
- for($i=0; $i<$height; $i++) {
- $table .= "\n";
- for($j=0; $j<$width; $j++) {
- $image = isset($images[$i*$width+$j]) ? $images[$i*$width+$j] : null;
- if(!is_null($image)) {
- $table .= "\t" . build_thumb_html($image, $query) . " | \n";
- }
- else {
- $table .= "\t | \n";
- }
- }
- $table .= "
\n";
- }
- $table .= "
\n";
-
- return $table;
- }
-// }}}
}
add_event_listener(new Index());
?>
diff --git a/ext/index/theme.php b/ext/index/theme.php
new file mode 100644
index 00000000..62876be6
--- /dev/null
+++ b/ext/index/theme.php
@@ -0,0 +1,91 @@
+page_number = $page_number;
+ $this->total_pages = $total_pages;
+ $this->search_terms = $search_terms;
+ }
+
+ public function display_page($page, $page_title, $images) {
+ if(count($this->search_terms) == 0) {
+ $query = null;
+ $page_title = $config->get_string('title');
+ }
+ else {
+ $search_string = implode(' ', $this->search_terms);
+ $query = "search=".url_escape($search_string);
+ $page_title = html_escape($search_string);
+ if(count($images) > 0) {
+ $page->set_subheading("Page $page_number / $total_pages");
+ }
+ }
+ if($page_number > 1 || count($this->search_terms) > 0) {
+ // $page_title .= " / $page_number";
+ }
+
+ $nav = $this->build_navigation($this->page_number, $this->total_pages, $this->search_terms);
+ $page->set_title($page_title);
+ $page->set_heading($page_title);
+ $page->add_block(new Block("Navigation", $nav, "left", 0));
+ if(count($images) > 0) {
+ $page->add_block(new Block("Images", $this->build_table($images, $query), "main", 10));
+ $page->add_block(new Paginator("index", $query, $this->page_number, $this->total_pages));
+ }
+ else {
+ $page->add_block(new Block("No Images Found", "No images were found to match the search criteria"));
+ }
+ }
+
+
+ private function build_navigation($page_number, $total_pages, $search_terms) {
+ $prev = $page_number - 1;
+ $next = $page_number + 1;
+
+ $u_tags = url_escape(implode(" ", $search_terms));
+ $query = empty($u_tags) ? null : "search=$u_tags";
+
+
+ $h_prev = ($page_number <= 1) ? "Prev" : "Prev";
+ $h_index = "Index";
+ $h_next = ($page_number >= $total_pages) ? "Next" : "Next";
+
+ $h_search_string = count($search_terms) == 0 ? "Search" : html_escape(implode(" ", $search_terms));
+ $h_search_link = make_link("index");
+ $h_search = "
+
+ ";
+
+ return "$h_prev | $h_index | $h_next
$h_search";
+ }
+
+ private function build_table($images, $query) {
+ global $config;
+
+ $width = $config->get_int('index_width');
+ $height = $config->get_int('index_height');
+
+ $table = "\n";
+ for($i=0; $i<$height; $i++) {
+ $table .= "\n";
+ for($j=0; $j<$width; $j++) {
+ $image = isset($images[$i*$width+$j]) ? $images[$i*$width+$j] : null;
+ if(!is_null($image)) {
+ $table .= "\t" . build_thumb_html($image, $query) . " | \n";
+ }
+ else {
+ $table .= "\t | \n";
+ }
+ }
+ $table .= "
\n";
+ }
+ $table .= "
\n";
+
+ return $table;
+ }
+}
+?>