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
|
<?php
/*
Copyright (c) 2001 - 2007 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 'lib/init.php';
/* Display the headers and menus */
require_once Config::get('prefix') . '/templates/header.inc.php';
echo '<div id="browse_content">';
switch($_REQUEST['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 = $user->prefs['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 = $user->prefs['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 'song':
Browse::set_type('song');
$song_ids = Browse::get_objects();
Browse::show_objects($song_ids);
break;
case 'catalog':
break;
default:
break;
} // end Switch $action
echo '</div>';
/* Show the Footer */
show_footer();
?>
|