Subversion Repositories svnkaklik

Rev

Go to most recent revision | Details | Last modification | View Log

Rev Author Line No. Line
6 kaklik 1
<?php
2
/*************************
3
  Coppermine Photo Gallery
4
  ************************
5
  Copyright (c) 2003-2005 Coppermine Dev Team
6
  v1.1 originaly written by Gregory DEMAR
7
 
8
  This program is free software; you can redistribute it and/or modify
9
  it under the terms of the GNU General Public License as published by
10
  the Free Software Foundation; either version 2 of the License, or
11
  (at your option) any later version.
12
  ********************************************
13
  Coppermine version: 1.3.3
14
  $Source: /cvsroot/coppermine/stable/index.php,v $
15
  $Revision: 1.17 $
16
  $Author: gaugau $
17
  $Date: 2005/04/19 03:17:11 $
18
**********************************************/
19
 
20
// Check if standalone is installed in a portal like phpNuke (added by DJMaze)
21
$DIR=preg_split("/[\/\\\]/",dirname($_SERVER['PATH_TRANSLATED']));
22
if ($DIR[count($DIR)-2] == "modules") {
23
    echo "<html><body><h1>ERROR</h1>You installed the standalone Coppermine into your Nuke portal.<br>".
24
         "Please download and install a CPG Port: <a href=\"http://sourceforge.net/project/showfiles.php?group_id=89658\">CPG for PostNuke OR CPG for PHPnuke</a></body></html>";
25
    die();
26
} // end check
27
define('IN_COPPERMINE', true);
28
define('INDEX_PHP', true);
29
 
30
require('include/init.inc.php');
31
if ($CONFIG['enable_smilies']) include("include/smilies.inc.php");
32
/**
33
 * Local functions definition
34
 */
35
function html_albummenu($id)
36
{
37
    global $template_album_admin_menu, $lang_album_admin_menu;
38
 
39
    static $template = '';
40
 
41
    if ($template == '') {
42
        $params = array('{CONFIRM_DELETE}' => $lang_album_admin_menu['confirm_delete'],
43
            '{DELETE}' => $lang_album_admin_menu['delete'],
44
            '{MODIFY}' => $lang_album_admin_menu['modify'],
45
            '{EDIT_PICS}' => $lang_album_admin_menu['edit_pics'],
46
            );
47
 
48
        $template = template_eval($template_album_admin_menu, $params);
49
    }
50
 
51
    $params = array('{ALBUM_ID}' => $id,
52
        );
53
 
54
    return template_eval($template, $params);
55
}
56
 
57
function get_subcat_data($parent, &$cat_data, &$album_set_array, $level, $ident = '')
58
{
59
    global $CONFIG, $HIDE_USER_CAT, $FORBIDDEN_SET,$cpg_show_private_album;
60
 
61
    $album_filter='';
62
    $pic_filter='';
63
    if (!empty($FORBIDDEN_SET) && !$cpg_show_private_album) {
64
        $album_filter = ' and '.str_replace('p.','a.',$FORBIDDEN_SET);
65
        $pic_filter = ' and '.str_replace('p.',$CONFIG['TABLE_PICTURES'].'.',$FORBIDDEN_SET);
66
    }
67
 
68
    $result = db_query("SELECT cid, name, description, thumb FROM {$CONFIG['TABLE_CATEGORIES']} WHERE parent = '$parent'  ORDER BY pos");
69
 
70
    if (mysql_num_rows($result) > 0) {
71
        $rowset = db_fetch_rowset($result);
72
        foreach ($rowset as $subcat) {
73
            if ($subcat['cid'] == USER_GAL_CAT) {
74
                $sql = "SELECT aid FROM {$CONFIG['TABLE_ALBUMS']} as a WHERE category>=" . FIRST_USER_CAT.$album_filter;
75
                $result = db_query($sql);
76
                $album_count = mysql_num_rows($result);
77
                while ($row = mysql_fetch_array($result)) {
78
                    $album_set_array[] = $row['aid'];
79
                } // while
80
                mysql_free_result($result);
81
 
82
                $result = db_query("SELECT count(*) FROM {$CONFIG['TABLE_PICTURES']} as p, {$CONFIG['TABLE_ALBUMS']} as a WHERE p.aid = a.aid AND category >= " . FIRST_USER_CAT.$album_filter);
83
                $nbEnr = mysql_fetch_array($result);
84
                $pic_count = $nbEnr[0];
85
 
86
                $subcat['description'] = preg_replace("/<br.*?>[\r\n]*/i", '<br />' . $ident , bb_decode($subcat['description']));
87
                $link = $ident . "<a href=\"index.php?cat={$subcat['cid']}\">{$subcat['name']}</a>";
88
                if ($album_count) {
89
                    $cat_data[] = array($link, $ident . $subcat['description'], $album_count, $pic_count);
90
                    $HIDE_USER_CAT = 0;
91
                } else {
92
                    $HIDE_USER_CAT = 1;
93
                }
94
            } else {
95
                                $unaliased_album_filter = str_replace('a.','',$album_filter);
96
                $result = db_query("SELECT aid FROM {$CONFIG['TABLE_ALBUMS']} WHERE category = {$subcat['cid']}".$unaliased_album_filter);
97
                $album_count = mysql_num_rows($result);
98
                while ($row = mysql_fetch_array($result)) {
99
                    $album_set_array[] = $row['aid'];
100
                } // while
101
                mysql_free_result($result);
102
 
103
                $result = db_query("SELECT count(*) FROM {$CONFIG['TABLE_PICTURES']} as p, {$CONFIG['TABLE_ALBUMS']} as a WHERE p.aid = a.aid AND category = {$subcat['cid']}".$album_filter);
104
                $nbEnr = mysql_fetch_array($result);
105
                mysql_free_result($result);
106
                $pic_count = $nbEnr[0];
107
                if ($subcat['thumb']>0) {
108
                    $sql = "SELECT filepath, filename, url_prefix, pwidth, pheight ".
109
                        "FROM {$CONFIG['TABLE_PICTURES']} ".
110
                        "WHERE pid='{$subcat['thumb']}'".$pic_filter;
111
                    $result = db_query($sql);
112
                    if (mysql_num_rows($result)) {
113
                        $picture = mysql_fetch_array($result);
114
                        mysql_free_result($result);
115
                        $pic_url =  get_pic_url($picture, 'thumb');
116
                        if (!is_image($picture['filename'])) {
117
                                $image_info = getimagesize($pic_url);
118
                                $picture['pwidth'] = $image_info[0];
119
                                $picture['pheight'] = $image_info[1];
120
                        }
121
                        $image_size = compute_img_size($picture['pwidth'], $picture['pheight'], $CONFIG['alb_list_thumb_size']);
122
                        $user_thumb = "<img src=\"" . $pic_url . "\" class=\"image\" {$image_size['geom']} border=\"0\" alt=\"\">";
123
                        $user_thumb = "<a href=\"index.php?cat={$subcat['cid']}\">".$user_thumb."</a>";
124
                    }
125
                }else{
126
                    $user_thumb ="";
127
                }
128
                $subcat['name'] = $subcat['name'];
129
                $subcat['description'] = preg_replace("/<br.*?>[\r\n]*/i", '<br />', bb_decode($subcat['description']));
130
                $link = "<a href=\"index.php?cat={$subcat['cid']}\">{$subcat['name']}</a>";
131
                $user_thumb = $ident.$user_thumb;
132
                if ($pic_count == 0 && $album_count == 0) {
133
                                        $user_thumb = $ident;
134
                    $cat_data[] = array($link, $subcat['description'],'cat_thumb' =>$user_thumb);
135
                } else {
136
                    // Check if you need to show subcat_level
137
                    if ($level == $CONFIG['subcat_level']) {
138
                        $cat_albums = list_cat_albums($subcat['cid']);
139
                    } else {
140
                        $cat_albums = '';
141
                    }
142
                    $cat_data[] = array($link, $subcat['description'], $album_count, $pic_count, 'cat_albums' => $cat_albums,'cat_thumb' =>$user_thumb);
143
                }
144
            }
145
 
146
            if ($level > 1) get_subcat_data($subcat['cid'], $cat_data, $album_set_array, $level -1, $ident . "</td><td><img src=\"images/spacer.gif\" width=\"20\" height=\"1\"></td><td>");
147
        }
148
    }
149
}
150
// List all categories
151
function get_cat_list(&$breadcrumb, &$cat_data, &$statistics)
152
{
153
    global $HTTP_GET_VARS, $CONFIG, $ALBUM_SET, $CURRENT_CAT_NAME, $BREADCRUMB_TEXT, $STATS_IN_ALB_LIST, $FORBIDDEN_SET;
154
    global $HIDE_USER_CAT,$cpg_show_private_album;
155
    global $cat;
156
    global $lang_list_categories, $lang_errors;
157
 
158
    // Build the breadcrumb
159
    breadcrumb($cat, $breadcrumb, $BREADCRUMB_TEXT);
160
    // Build the category list
161
    $cat_data = array();
162
    $album_set_array = array();
163
    get_subcat_data($cat, $cat_data, $album_set_array, $CONFIG['subcat_level']);
164
 
165
    $album_filter='';
166
    $pic_filter='';
167
    $cat = (int) $cat;
168
    if (!empty($FORBIDDEN_SET) && !$cpg_show_private_album) {
169
        $album_filter = ' and '.str_replace('p.','a.',$FORBIDDEN_SET);
170
        $pic_filter = ' and '.$FORBIDDEN_SET;
171
    }
172
 
173
    // Add the albums in the current category to the album set
174
    //if ($cat) {
175
        if ($cat == USER_GAL_CAT) {
176
            $sql = "SELECT aid FROM {$CONFIG['TABLE_ALBUMS']} as a WHERE category >= " . FIRST_USER_CAT.$album_filter;
177
            $result = db_query($sql);
178
        } else {
179
            $sql = "SELECT aid FROM {$CONFIG['TABLE_ALBUMS']} as a WHERE category = '$cat'".$album_filter;
180
            $result = db_query($sql);
181
        }
182
        while ($row = mysql_fetch_array($result)) {
183
            $album_set_array[] = $row['aid'];
184
        } // while
185
        mysql_free_result($result);
186
    //}
187
    if (count($album_set_array)&&$cat) {
188
        $set = '';
189
        foreach ($album_set_array as $album) $set .= $album . ',';
190
        $set = substr($set, 0, -1);
191
        $current_album_set = "AND aid IN ($set) ";
192
        $ALBUM_SET .= $current_album_set;
193
    } elseif ($cat) {
194
        $current_album_set = "AND aid IN (-1) ";
195
        $ALBUM_SET .= $current_album_set;
196
    }
197
    // Gather gallery statistics
198
    if ($cat == 0) {
199
        $result = db_query("SELECT count(*) FROM {$CONFIG['TABLE_ALBUMS']} as a WHERE 1".$album_filter);
200
        $nbEnr = mysql_fetch_array($result);
201
        $album_count = $nbEnr[0];
202
        mysql_free_result($result);
203
 
204
        $sql = "SELECT count(*) FROM {$CONFIG['TABLE_PICTURES']} as p ".
205
                'LEFT JOIN '.$CONFIG['TABLE_ALBUMS'].' as a '.
206
                'ON a.aid=p.aid '.
207
                'WHERE 1'.$pic_filter;
208
        $result = db_query($sql);
209
        $nbEnr = mysql_fetch_array($result);
210
        $picture_count = $nbEnr[0];
211
        mysql_free_result($result);
212
 
213
        $sql = "SELECT count(*) FROM {$CONFIG['TABLE_COMMENTS']} as c ".
214
                'LEFT JOIN '.$CONFIG['TABLE_PICTURES'].' as p '.
215
                'ON c.pid=p.pid '.
216
                'LEFT JOIN '.$CONFIG['TABLE_ALBUMS'].' as a '.
217
                'ON a.aid=p.aid '.
218
                'WHERE 1'.$pic_filter;
219
        $result = db_query($sql);
220
        $nbEnr = mysql_fetch_array($result);
221
        $comment_count = $nbEnr[0];
222
        mysql_free_result($result);
223
 
224
        $sql = "SELECT count(*) FROM {$CONFIG['TABLE_CATEGORIES']} WHERE 1";
225
        $result = db_query($sql);
226
        $nbEnr = mysql_fetch_array($result);
227
        $cat_count = $nbEnr[0] - $HIDE_USER_CAT;
228
        mysql_free_result($result);
229
 
230
        $sql = "SELECT sum(hits) FROM {$CONFIG['TABLE_PICTURES']} as p ".
231
                'LEFT JOIN '.$CONFIG['TABLE_ALBUMS'].' as a '.
232
                'ON p.aid=a.aid '.
233
                'WHERE 1'.$pic_filter;
234
        $result = db_query($sql);
235
        $nbEnr = mysql_fetch_array($result);
236
        $hit_count = (int)$nbEnr[0];
237
        mysql_free_result($result);
238
 
239
        if (count($cat_data)) {
240
            $statistics = strtr($lang_list_categories['stat1'], array('[pictures]' => $picture_count,
241
                    '[albums]' => $album_count,
242
                    '[cat]' => $cat_count,
243
                    '[comments]' => $comment_count,
244
                    '[views]' => $hit_count));
245
        } else {
246
            $STATS_IN_ALB_LIST = true;
247
            $statistics = strtr($lang_list_categories['stat3'], array('[pictures]' => $picture_count,
248
                    '[albums]' => $album_count,
249
                    '[comments]' => $comment_count,
250
                    '[views]' => $hit_count));
251
        }
252
    } elseif ($cat >= FIRST_USER_CAT && $ALBUM_SET) {
253
        $result = db_query("SELECT count(*) FROM {$CONFIG['TABLE_ALBUMS']} WHERE 1 $current_album_set");
254
        $nbEnr = mysql_fetch_array($result);
255
        $album_count = $nbEnr[0];
256
        mysql_free_result($result);
257
 
258
        $result = db_query("SELECT count(*) FROM {$CONFIG['TABLE_PICTURES']} WHERE 1 $current_album_set");
259
        $nbEnr = mysql_fetch_array($result);
260
        $picture_count = $nbEnr[0];
261
        mysql_free_result($result);
262
 
263
        $result = db_query("SELECT sum(hits) FROM {$CONFIG['TABLE_PICTURES']} WHERE 1 $current_album_set");
264
        $nbEnr = mysql_fetch_array($result);
265
        $hit_count = (int)$nbEnr[0];
266
        mysql_free_result($result);
267
 
268
        $statistics = strtr($lang_list_categories['stat2'], array('[pictures]' => $picture_count,
269
                '[albums]' => $album_count,
270
                '[views]' => $hit_count));
271
    } else {
272
        $statistics = '';
273
    }
274
}
275
 
276
function list_users()
277
{
278
    global $CONFIG, $PAGE, $FORBIDDEN_SET;
279
    global $lang_list_users, $lang_errors, $template_user_list_info_box, $cpg_show_private_album;
280
 
281
    if (defined('UDB_INTEGRATION')) {
282
        $result = udb_list_users_query($user_count);
283
    } else {
284
//        $sql = "SELECT user_id," . "        user_name," . "        COUNT(DISTINCT a.aid) as alb_count," . "        COUNT(DISTINCT pid) as pic_count," . "        MAX(pid) as thumb_pid " . "FROM {$CONFIG['TABLE_USERS']} AS u " . "INNER JOIN {$CONFIG['TABLE_ALBUMS']} AS a ON category = " . FIRST_USER_CAT . " + user_id " . "INNER JOIN {$CONFIG['TABLE_PICTURES']} AS p ON p.aid = a.aid " . "WHERE approved = 'YES' " . "$FORBIDDEN_SET " . "GROUP BY user_id " . "ORDER BY user_name ";
285
// Fixed correct album count DJMaze
286
        $sql = "SELECT user_id, " .
287
               "user_name, " .
288
               "COUNT(DISTINCT a.aid) as alb_count, " .
289
               "COUNT(DISTINCT pid) as pic_count, " .
290
               "MAX(pid) as thumb_pid " .
291
               "FROM {$CONFIG['TABLE_USERS']} AS u " .
292
               "INNER JOIN {$CONFIG['TABLE_ALBUMS']} AS a ON category = " . FIRST_USER_CAT . " + user_id " .
293
               "LEFT JOIN {$CONFIG['TABLE_PICTURES']} AS p ON (p.aid = a.aid AND approved = 'YES') ";
294
        if ($FORBIDDEN_SET != "") $sql .= "WHERE $FORBIDDEN_SET ";
295
        $sql .= "GROUP BY user_id " .
296
                "ORDER BY user_name";
297
 
298
        $result = db_query($sql);
299
 
300
        $user_count = mysql_num_rows($result);
301
    }
302
 
303
    if (!$user_count) {
304
        msg_box($lang_list_users['user_list'], $lang_list_users['no_user_gal'], '', '', '100%');
305
        mysql_free_result($result);
306
        return;
307
    }
308
 
309
    $user_per_page = $CONFIG['thumbcols'] * $CONFIG['thumbrows'];
310
    $totalPages = ceil($user_count / $user_per_page);
311
    if ($PAGE > $totalPages) $PAGE = 1;
312
    $lower_limit = ($PAGE-1) * $user_per_page;
313
    $upper_limit = min($user_count, $PAGE * $user_per_page);
314
    $row_count = $upper_limit - $lower_limit;
315
 
316
    if (defined('UDB_INTEGRATION')) {
317
        $rowset = udb_list_users_retrieve_data($result, $lower_limit, $row_count);
318
    } else {
319
        $rowset = array();
320
        $i = 0;
321
        mysql_data_seek($result, $lower_limit);
322
        while (($row = mysql_fetch_array($result)) && ($i++ < $row_count)) $rowset[] = $row;
323
        mysql_free_result($result);
324
    }
325
 
326
    $user_list = array();
327
    foreach ($rowset as $user) {
328
        $user_thumb = '<img src="images/nopic.jpg" class="image" border="0" />';
329
        $user_pic_count = $user['pic_count'];
330
        $user_thumb_pid = $user['thumb_pid'];
331
        $user_album_count = $user['alb_count'];
332
 
333
        if ($user_pic_count) {
334
 
335
                        if ($CONFIG['show_private']){
336
                                $image_size = compute_img_size(100, 75, $CONFIG['alb_list_thumb_size']);
337
                                $user_thumb = "<img src=\"images/private.jpg\" {$image_size['geom']} alt=\"\" border=\"0\" class=\"image\" />";
338
                        }
339
            $sql = "SELECT filepath, filename, url_prefix, pwidth, pheight " . "FROM {$CONFIG['TABLE_PICTURES']} " . "WHERE pid='$user_thumb_pid'";
340
            $result = db_query($sql);
341
 
342
            if (mysql_num_rows($result)) {
343
                $picture = mysql_fetch_array($result);
344
                mysql_free_result($result);
345
                $pic_url =  get_pic_url($picture, 'thumb');
346
                if (!is_image($picture['filename'])) {
347
                        $image_info = getimagesize($pic_url);
348
                        $picture['pwidth'] = $image_info[0];
349
                        $picture['pheight'] = $image_info[1];
350
                }
351
                $image_size = compute_img_size($picture['pwidth'], $picture['pheight'], $CONFIG['alb_list_thumb_size']);
352
                    $user_thumb = "<img src=\"" . get_pic_url($picture, 'thumb') . "\" class=\"image\" {$image_size['geom']} border=\"0\" alt=\"\">";
353
 
354
            }
355
 
356
                }
357
        $albums_txt = sprintf($lang_list_users['n_albums'], $user_album_count);
358
        $pictures_txt = sprintf($lang_list_users['n_pics'], $user_pic_count);
359
 
360
        $params = array('{USER_NAME}' => $user['user_name'],
361
            '{USER_ID}' => $user['user_id'],
362
            '{ALBUMS}' => $albums_txt,
363
            '{PICTURES}' => $pictures_txt,
364
            );
365
        $caption = template_eval($template_user_list_info_box, $params);
366
 
367
        $user_list[] = array('cat' => FIRST_USER_CAT + $user['user_id'],
368
            'image' => $user_thumb,
369
            'caption' => $caption,
370
            );
371
    }
372
    theme_display_thumbnails($user_list, $user_count, '', '', 1, $PAGE, $totalPages, false, true, 'user');
373
}
374
// List all albums
375
function list_albums()
376
{
377
    global $CONFIG, $USER, $USER_DATA, $PAGE, $lastup_date_fmt,$FORBIDDEN_SET;
378
    global $cat;
379
    global $lang_list_albums, $lang_errors,$cpg_show_private_album;
380
 
381
    $alb_per_page = $CONFIG['albums_per_page'];
382
    $maxTab = $CONFIG['max_tabs'];
383
 
384
    $album_filter='';
385
    $pic_filter='';
386
    $pic_subquery='';
387
 
388
    if (!empty($FORBIDDEN_SET) && !$cpg_show_private_album) {
389
        $album_filter = ' and '.str_replace('p.','a.',$FORBIDDEN_SET);
390
        $pic_filter = ' and '.$FORBIDDEN_SET;
391
    }
392
 
393
 
394
    $result = db_query("SELECT count(*) FROM {$CONFIG['TABLE_ALBUMS']} as a WHERE category = '$cat'".$album_filter);
395
    $nbEnr = mysql_fetch_array($result);
396
    $nbAlb = $nbEnr[0];
397
    mysql_free_result($result);
398
 
399
    if (!$nbAlb) return;
400
 
401
    $totalPages = ceil($nbAlb / $alb_per_page);
402
 
403
    if ($PAGE > $totalPages) $PAGE = 1;
404
    $lower_limit = ($PAGE-1) * $alb_per_page;
405
    $upper_limit = min($nbAlb, $PAGE * $alb_per_page);
406
    $limit = "LIMIT " . $lower_limit . "," . ($upper_limit - $lower_limit);
407
 
408
    $sql = 'SELECT a.aid, a.title, a.description, visibility, filepath, '.
409
           'filename, url_prefix, pwidth, pheight '.
410
           'FROM '.$CONFIG['TABLE_ALBUMS'].' as a '.
411
           'LEFT JOIN '.$CONFIG['TABLE_PICTURES'].' as p '.
412
           'ON a.thumb=p.pid '.
413
           'WHERE category='.$cat.$album_filter.
414
           ' ORDER BY a.pos '.
415
           $limit;
416
 
417
 
418
    $alb_thumbs_q = db_query($sql);
419
    $alb_thumbs = db_fetch_rowset($alb_thumbs_q);
420
    mysql_free_result($alb_thumbs_q);
421
 
422
    $disp_album_count = count($alb_thumbs);
423
    $album_set = '';
424
    foreach($alb_thumbs as $value) {
425
        $album_set .= $value['aid'] . ', ';
426
    }
427
    $album_set = '(' . substr($album_set, 0, -2) . ')';
428
 
429
    $sql = "SELECT aid, count(pid) as pic_count, max(pid) as last_pid, max(ctime) as last_upload ".
430
           "FROM {$CONFIG['TABLE_PICTURES']} ".
431
           "WHERE aid IN $album_set AND approved = 'YES' ".
432
           "GROUP BY aid";
433
    $alb_stats_q = db_query($sql);
434
    $alb_stats = db_fetch_rowset($alb_stats_q);
435
    mysql_free_result($alb_stats_q);
436
 
437
    foreach($alb_stats as $key => $value) {
438
        $cross_ref[$value['aid']] = &$alb_stats[$key];
439
    }
440
 
441
    for ($alb_idx = 0; $alb_idx < $disp_album_count; $alb_idx++) {
442
        $alb_thumb = &$alb_thumbs[$alb_idx];
443
        $aid = $alb_thumb['aid'];
444
 
445
        if (isset($cross_ref[$aid])) {
446
            $alb_stat = $cross_ref[$aid];
447
            $count = $alb_stat['pic_count'];
448
        } else {
449
            $alb_stat = array();
450
            $count = 0;
451
        }
452
        // Inserts a thumbnail if the album contains 1 or more images
453
 
454
        $visibility = $alb_thumb['visibility'];
455
        if ($visibility == '0' || $visibility == (FIRST_USER_CAT + USER_ID) || in_array($visibility, $USER_DATA['groups']) || $USER_DATA['can_see_all_albums'] || $CONFIG['allow_private_albums']==0) {
456
            if ($count > 0) {
457
                if ($alb_thumb['filename']) {
458
                    $picture = &$alb_thumb;
459
                } else {
460
                    $sql = "SELECT filepath, filename, url_prefix, pwidth, pheight ".
461
                           "FROM {$CONFIG['TABLE_PICTURES']} ".
462
                           "WHERE pid='{$alb_stat['last_pid']}'";
463
                    $result = db_query($sql);
464
                    $picture = mysql_fetch_array($result);
465
                    mysql_free_result($result);
466
                }
467
                $pic_url =  get_pic_url($picture, 'thumb');
468
                if (!is_image($picture['filename'])) {
469
                        $image_info = getimagesize($pic_url);
470
                        $picture['pwidth'] = $image_info[0];
471
                        $picture['pheight'] = $image_info[1];
472
                }
473
                $image_size = compute_img_size($picture['pwidth'], $picture['pheight'], $CONFIG['alb_list_thumb_size']);
474
                $alb_list[$alb_idx]['thumb_pic'] = "<img src=\"" . $pic_url . "\" class=\"image\" {$image_size['geom']} border=\"0\" alt=\"{$picture['filename']}\">";
475
            } else { // Inserts an empty thumbnail if the album contains 0 images
476
                $image_size = compute_img_size(100, 75, $CONFIG['alb_list_thumb_size']);
477
 
478
                $alb_list[$alb_idx]['thumb_pic'] = "<img src=\"images/nopic.jpg\" {$image_size['geom']} alt=\"\" border=\"0\" class=\"image\" />";
479
            }
480
        } elseif ($CONFIG['show_private']) {
481
            $image_size = compute_img_size(100, 75, $CONFIG['alb_list_thumb_size']);
482
            $alb_list[$alb_idx]['thumb_pic'] = "<img src=\"images/private.jpg\" {$image_size['geom']} alt=\"\" border=\"0\" class=\"image\" />";
483
 
484
        }
485
        // Prepare everything
486
 
487
        if ($visibility == '0' || $visibility == (FIRST_USER_CAT + USER_ID) || in_array($visibility, $USER_DATA['groups']) || $USER_DATA['can_see_all_albums'] || $CONFIG['allow_private_albums']==0) {
488
            $last_upload_date = $count ? localised_date($alb_stat['last_upload'], $lastup_date_fmt) : '';
489
            $alb_list[$alb_idx]['aid'] = $alb_thumb['aid'];
490
            $alb_list[$alb_idx]['album_title'] = $alb_thumb['title'];
491
            $alb_list[$alb_idx]['album_desc'] = bb_decode($alb_thumb['description']);
492
            $alb_list[$alb_idx]['pic_count'] = $count;
493
            $alb_list[$alb_idx]['last_upl'] = $last_upload_date;
494
            $alb_list[$alb_idx]['album_info'] = sprintf($lang_list_albums['n_pictures'], $count) . ($count ? sprintf($lang_list_albums['last_added'], $last_upload_date) : "");
495
            $alb_list[$alb_idx]['album_adm_menu'] = (GALLERY_ADMIN_MODE || (USER_ADMIN_MODE && $cat == USER_ID + FIRST_USER_CAT)) ? html_albummenu($alb_thumb['aid']) : ' ';
496
        } elseif ($CONFIG['show_private']) { // uncomment this else block to show private album description
497
            $last_upload_date = $count ? localised_date($alb_stat['last_upload'], $lastup_date_fmt) : '';
498
            $alb_list[$alb_idx]['aid'] = $alb_thumb['aid'];
499
            $alb_list[$alb_idx]['album_title'] = $alb_thumb['title'];
500
            $alb_list[$alb_idx]['album_desc'] = bb_decode($alb_thumb['description']);
501
            $alb_list[$alb_idx]['pic_count'] = $count;
502
            $alb_list[$alb_idx]['last_upl'] = $last_upload_date;
503
            $alb_list[$alb_idx]['album_info'] = sprintf($lang_list_albums['n_pictures'], $count) . ($count ? sprintf($lang_list_albums['last_added'], $last_upload_date) : "");
504
            $alb_list[$alb_idx]['album_adm_menu'] = (GALLERY_ADMIN_MODE || (USER_ADMIN_MODE && $cat == USER_ID + FIRST_USER_CAT)) ? html_albummenu($alb_thumb['aid']) : ' ';
505
        }
506
    }
507
 
508
    theme_display_album_list($alb_list, $nbAlb, $cat, $PAGE, $totalPages);
509
}
510
 
511
/**
512
 */
513
// List category albums
514
// This has been added to list the category albums largely a repetition of code elsewhere
515
// Redone for a cleaner approach
516
function list_cat_albums($cat = 0)
517
{
518
    global $CONFIG, $USER, $lastup_date_fmt, $HTTP_GET_VARS, $USER_DATA, $FORBIDDEN_SET;
519
    global $lang_list_albums, $lang_errors,$cpg_show_private_album;
520
    $PAGE = 1;
521
    if ($cat == 0) {
522
        return '';
523
    }
524
 
525
    $alb_per_page = $CONFIG['albums_per_page'];
526
    $maxTab = $CONFIG['max_tabs'];
527
 
528
    $album_filter='';
529
    $pic_filter='';
530
    if (!empty($FORBIDDEN_SET) && !$cpg_show_private_album) {
531
        $album_filter = ' and '.str_replace('p.','a.',$FORBIDDEN_SET);
532
        $pic_filter = ' and '.$FORBIDDEN_SET;
533
    }
534
 
535
    $sql = "SELECT count(*) FROM {$CONFIG['TABLE_ALBUMS']} as a WHERE category = '$cat'".$album_filter;
536
    $result = db_query($sql);
537
    $nbEnr = mysql_fetch_array($result);
538
    $nbAlb = $nbEnr[0];
539
    mysql_free_result($result);
540
 
541
    if ($nbAlb == 0) {
542
        return;
543
    }
544
 
545
    $totalPages = ceil($nbAlb / $alb_per_page);
546
 
547
    if ($PAGE > $totalPages) $PAGE = 1;
548
    $lower_limit = ($PAGE-1) * $alb_per_page;
549
    $upper_limit = min($nbAlb, $PAGE * $alb_per_page);
550
    $limit = "LIMIT " . $lower_limit . "," . ($upper_limit - $lower_limit);
551
 
552
 
553
    /*
554
    $sql = "SELECT a.aid, a.title, a.description, visibility, filepath, ".
555
           "filename, url_prefix, pwidth, pheight ".
556
           "FROM {$CONFIG['TABLE_ALBUMS']} as a ".
557
           "LEFT JOIN {$CONFIG['TABLE_PICTURES']} as p ON thumb=pid ".
558
           "WHERE category = $cat ORDER BY a.pos ".$limit;
559
 
560
    */
561
    $sql = 'SELECT a.aid, a.title, a.description, visibility, filepath, '.
562
           'filename, url_prefix, pwidth, pheight '.
563
           'FROM '.$CONFIG['TABLE_ALBUMS'].' as a '.
564
           'LEFT JOIN '.$CONFIG['TABLE_PICTURES'].' as p '.
565
           'ON a.thumb=p.pid '.
566
           'WHERE category='.$cat.$album_filter.
567
           ' ORDER BY a.pos '.
568
           $limit;
569
 
570
    $alb_thumbs_q = db_query($sql);
571
    $alb_thumbs = db_fetch_rowset($alb_thumbs_q);
572
    mysql_free_result($alb_thumbs_q);
573
 
574
    $disp_album_count = count($alb_thumbs);
575
    $album_set = '';
576
    foreach($alb_thumbs as $value) {
577
        $album_set .= $value['aid'] . ', ';
578
    }
579
    $album_set = '(' . substr($album_set, 0, -2) . ')';
580
 
581
    $sql = "SELECT aid, count(pid) as pic_count, max(pid) as last_pid, max(ctime) as last_upload ".
582
           "FROM {$CONFIG['TABLE_PICTURES']} ".
583
           "WHERE aid IN $album_set AND approved = 'YES' ".
584
           "GROUP BY aid";
585
    $alb_stats_q = db_query($sql);
586
    $alb_stats = db_fetch_rowset($alb_stats_q);
587
    mysql_free_result($alb_stats_q);
588
 
589
    foreach($alb_stats as $key => $value) {
590
        $cross_ref[$value['aid']] = &$alb_stats[$key];
591
    }
592
 
593
    for ($alb_idx = 0; $alb_idx < $disp_album_count; $alb_idx++) {
594
        $alb_thumb = &$alb_thumbs[$alb_idx];
595
        $aid = $alb_thumb['aid'];
596
 
597
        if (isset($cross_ref[$aid])) {
598
            $alb_stat = $cross_ref[$aid];
599
            $count = $alb_stat['pic_count'];
600
        } else {
601
            $alb_stat = array();
602
            $count = 0;
603
        }
604
        // Inserts a thumbnail if the album contains 1 or more images
605
        $visibility = $alb_thumb['visibility'];
606
        if ($visibility == '0' || $visibility == (FIRST_USER_CAT + USER_ID) || in_array($visibility, $USER_DATA['groups']) || $USER_DATA['can_see_all_albums'] || $CONFIG['allow_private_albums']==0) { // test for visibility
607
            if ($count > 0) { // Inserts a thumbnail if the album contains 1 or more images
608
                if ($alb_thumb['filename']) {
609
                    $picture = &$alb_thumb;
610
                } else {
611
                    $sql = "SELECT filepath, filename, url_prefix, pwidth, pheight " . "FROM {$CONFIG['TABLE_PICTURES']} " . "WHERE pid='{$alb_stat['last_pid']}'";
612
                    $result = db_query($sql);
613
                    $picture = mysql_fetch_array($result);
614
                    mysql_free_result($result);
615
                }
616
                $pic_url =  get_pic_url($picture, 'thumb');
617
                if (!is_image($picture['filename'])) {
618
                        $image_info = getimagesize($pic_url);
619
                        $picture['pwidth'] = $image_info[0];
620
                        $picture['pheight'] = $image_info[1];
621
                }
622
                $image_size = compute_img_size($picture['pwidth'], $picture['pheight'], $CONFIG['alb_list_thumb_size']);
623
                $alb_list[$alb_idx]['thumb_pic'] = "<img src=\"" . $pic_url . "\" class=\"image\" {$image_size['geom']} border=\"0\" alt=\"{$picture['filename']}\">";
624
            } else { // Inserts an empty thumbnail if the album contains 0 images
625
                $image_size = compute_img_size(100, 75, $CONFIG['alb_list_thumb_size']);
626
                $alb_list[$alb_idx]['thumb_pic'] = "<img src=\"images/nopic.jpg\" {$image_size['geom']} alt=\"\" border=\"0\" class=\"image\" />";
627
            }
628
        } elseif ($CONFIG['show_private']) {
629
            $image_size = compute_img_size(100, 75, $CONFIG['alb_list_thumb_size']);
630
            $alb_list[$alb_idx]['thumb_pic'] = "<img src=\"images/private.jpg\" {$image_size['geom']} alt=\"\" border=\"0\" class=\"image\" />";
631
        }
632
        // Prepare everything
633
        if ($visibility == '0' || $visibility == (FIRST_USER_CAT + USER_ID) || in_array($visibility, $USER_DATA['groups']) || $USER_DATA['can_see_all_albums']) {
634
            $last_upload_date = $count ? localised_date($alb_stat['last_upload'], $lastup_date_fmt) : '';
635
            $alb_list[$alb_idx]['aid'] = $alb_thumb['aid'];
636
            $alb_list[$alb_idx]['album_title'] = $alb_thumb['title'];
637
            $alb_list[$alb_idx]['album_desc'] = bb_decode($alb_thumb['description']);
638
            $alb_list[$alb_idx]['pic_count'] = $count;
639
            $alb_list[$alb_idx]['last_upl'] = $last_upload_date;
640
            $alb_list[$alb_idx]['album_info'] = sprintf($lang_list_albums['n_pictures'], $count) . ($count ? sprintf($lang_list_albums['last_added'], $last_upload_date) : "");
641
            $alb_list[$alb_idx]['album_adm_menu'] = (GALLERY_ADMIN_MODE || (USER_ADMIN_MODE && $cat == USER_ID + FIRST_USER_CAT)) ? html_albummenu($alb_thumb['aid']) : '';
642
        } elseif ($CONFIG['show_private']) { // uncomment this else block to show private album description
643
            $last_upload_date = $count ? localised_date($alb_stat['last_upload'], $lastup_date_fmt) : '';
644
            $alb_list[$alb_idx]['aid'] = $alb_thumb['aid'];
645
            $alb_list[$alb_idx]['album_title'] = $alb_thumb['title'];
646
            $alb_list[$alb_idx]['album_desc'] = bb_decode($alb_thumb['description']);
647
            $alb_list[$alb_idx]['pic_count'] = $count;
648
            $alb_list[$alb_idx]['last_upl'] = $last_upload_date;
649
            $alb_list[$alb_idx]['album_info'] = sprintf($lang_list_albums['n_pictures'], $count) . ($count ? sprintf($lang_list_albums['last_added'], $last_upload_date) : "");
650
            $alb_list[$alb_idx]['album_adm_menu'] = (GALLERY_ADMIN_MODE || (USER_ADMIN_MODE && $cat == USER_ID + FIRST_USER_CAT)) ? html_albummenu($alb_thumb['aid']) : '';
651
        }
652
    }
653
    ob_start();
654
    theme_display_album_list_cat($alb_list, $nbAlb, $cat, $PAGE, $totalPages);
655
    $cat_albums = ob_get_contents();
656
    ob_end_clean();
657
    return $cat_albums;
658
}
659
 
660
/**
661
 */
662
/**
663
 * Main code
664
 */
665
 
666
if (isset($HTTP_GET_VARS['page'])) {
667
    $PAGE = max((int)$HTTP_GET_VARS['page'], 1);
668
    $USER['lap'] = $PAGE;
669
} elseif (isset($USER['lap'])) {
670
    $PAGE = max((int)$USER['lap'], 1);
671
} else {
672
    $PAGE = 1;
673
}
674
 
675
if (isset($HTTP_GET_VARS['cat'])) {
676
    $cat = (int)$HTTP_GET_VARS['cat'];
677
}
678
// Gather data for categories
679
$breadcrumb = '';
680
$cat_data = array();
681
$statistics = '';
682
$STATS_IN_ALB_LIST = false;
683
$cpg_show_private_album = ($CONFIG['allow_private_albums'])?($CONFIG['show_private']):(true);
684
 
685
get_cat_list($breadcrumb, $cat_data, $statistics);
686
 
687
pageheader($BREADCRUMB_TEXT ? $BREADCRUMB_TEXT : $lang_index_php['welcome']);
688
 
689
$elements = preg_split("|/|", $CONFIG['main_page_layout'], -1, PREG_SPLIT_NO_EMPTY);
690
foreach ($elements as $element) {
691
    if (preg_match("/(\w+),*(\d+)*/", $element, $matches)) switch ($matches[1]) {
692
            case 'breadcrumb':
693
                // Added breadcrumb as a separate listable block from config
694
                if (($breadcrumb != '' || count($cat_data) > 0) && $cat !=0 ) theme_display_breadcrumb($breadcrumb, $cat_data);
695
                break;
696
 
697
            case 'catlist':
698
                if ($breadcrumb != '' || count($cat_data) > 0) theme_display_cat_list($breadcrumb, $cat_data, $statistics);
699
                if (isset($cat) && $cat == USER_GAL_CAT) list_users();
700
                flush();
701
                break;
702
 
703
            case 'alblist':
704
                list_albums();
705
                flush();
706
                break;
707
 
708
            case 'random':
709
                display_thumbnails('random', $cat, 1, $CONFIG['thumbcols'], max(1, $matches[2]), false);
710
                flush();
711
                break;
712
 
713
            case 'lastup':
714
                display_thumbnails('lastup', $cat, 1, $CONFIG['thumbcols'], max(1, $matches[2]), false);
715
                flush();
716
                break;
717
            case 'lastalb':
718
                display_thumbnails('lastalb', $cat, 1, $CONFIG['thumbcols'], max(1, $matches[2]), false);
719
                break;
720
 
721
            case 'topn':
722
                display_thumbnails('topn', $cat, 1, $CONFIG['thumbcols'], max(1, $matches[2]), false);
723
                flush();
724
                break;
725
 
726
            case 'toprated':
727
                display_thumbnails('toprated', $cat, 1, $CONFIG['thumbcols'], max(1, $matches[2]), false);
728
                flush();
729
                break;
730
 
731
            case 'lastcom':
732
                display_thumbnails('lastcom', $cat, 1, $CONFIG['thumbcols'], max(1, $matches[2]), false);
733
                flush();
734
                break;
735
 
736
            case 'lasthits':
737
                display_thumbnails('lasthits', $cat, 1, $CONFIG['thumbcols'], max(1, $matches[2]), false);
738
                flush();
739
                break;
740
 
741
            case 'anycontent':
742
                if ($cat == 0) {
743
                    include('anycontent.php');
744
                }
745
                flush();
746
                break;
747
        }
748
    }
749
 
750
    pagefooter();
751
    ob_end_flush();
752
    // Speed-up the random image query by 'keying' the image table
753
    if (time() - $CONFIG['randpos_interval'] > 86400) {
754
        $result = db_query("SELECT count(*) FROM {$CONFIG['TABLE_PICTURES']} WHERE 1");
755
        $nbEnr = mysql_fetch_array($result);
756
        mysql_free_result($result);
757
        $pic_count = $nbEnr[0];
758
        $granularity = floor($pic_count / RANDPOS_MAX_PIC);
759
        $result = db_query("UPDATE {$CONFIG['TABLE_PICTURES']} SET randpos = ROUND(RAND()*$granularity) WHERE 1");
760
        $result = db_query("UPDATE {$CONFIG['TABLE_CONFIG']} SET value = '" . time() . "' WHERE name = 'randpos_interval'");
761
    }
762
 
763
    ?>