summaryrefslogtreecommitdiffstats
path: root/browse.php
blob: 91918fa907835ba35eb70cc2fdb9050ba59d41fa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
<?php
/*

 Copyright (c) 2001 - 2005 Ampache.org
 All Rights Reserved

 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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

*/

/**
 *
 * Browse By Page
 * This page shows the browse menu, which allows you to browse by many different
 * fields including genre, artist, album, catalog, ??? 
 * this page also handles the actuall browse action
 * @package Web Interface
 * @catagory Browse
 * @author Karl Vollmer 06/24/05
 *
 */

/* Base Require */
require_once("modules/init.php");

/* Clean up incomming variables */
$action		= scrub_in($_REQUEST['action']);

/* Display the headers and menus */
show_template('header');

switch($action) {
	case 'file':
	case 'album':
		show_alphabet_list('albums','albums.php',$match);
		show_alphabet_form($match,_("Show Albums starting with"),"albums.php?action=match");

		/* Get the results and show them */
		$sql = "SELECT id FROM album WHERE name LIKE '$match%'";

		$view = new View();
		$view->import_session_view();

	        // if we are returning
	        if ($_REQUEST['keep_view']) {
	                $view->initialize();
	        }

	        // If we aren't keeping the view then initlize it
	        elseif ($sql) {
	                $db_results = mysql_query($sql, dbh());
	                $total_items = mysql_num_rows($db_results);
	                if ($match != "Show_all") { $offset_limit = $_SESSION['userdata']['offset_limit']; }
	                $view = new View($sql, 'albums.php','name',$total_items,$offset_limit);
	        }

	        else { $view = false; }

	        if ($view->base_sql) {
	                $albums = get_albums($view->sql);
                	show_albums($albums,$view);
		}		
	break;
	case 'artist':
                show_alphabet_list('artists','artists.php');
                show_alphabet_form('',_("Show Artists starting with"),"artists.php?action=match");
                show_artists();
	break;
	case 'genre':
		/* Create the Needed Object */
		$genre = new Genre();
	
		/* Setup the View object */
		$view = new View();
		$view->import_session_view();
		$genre->show_match_list($_REQUEST['match']);
		$sql = $genre->get_sql_from_match($_REQUEST['match']);

		if ($_REQUEST['keep_view']) { 
			$view->initialize();
		}
		else { 
			$db_results = mysql_query($sql, dbh());
			$total_items = mysql_num_rows($db_results);
			$offset_limit = 999999;
			if ($match != 'Show_All') { $offset_limit = $_SESSION['userdata']['offset_limit']; }
			$view = new View($sql, 'browse.php?action=genre','name',$total_items,$offset_limit);
		}
	
	        if ($view->base_sql) {
			$genres = $genre->get_genres($view->sql);
	                show_genres($genres,$view);
        	}
		
	break;

	case 'catalog':
	
	break;
	/* Throw recently added, updated here */
	default:

		/* Show Most Popular artist/album/songs */
		show_all_popular();

		/* Show Recent Additions */
		show_all_recent();

	break;

} // end Switch $action

/* Show the Footer */
show_footer();
?>