aboutsummaryrefslogtreecommitdiffstats
path: root/include/category_recent_cats.inc.php
blob: 3f11f81c17d24a03b584db8da137591ce0f5c323 (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
<?php
// +-----------------------------------------------------------------------+
// |                      category_recent_cats.inc.php                     |
// +-----------------------------------------------------------------------+
// | application   : PhpWebGallery <http://phpwebgallery.net>              |
// | branch        : BSF (Best So Far)                                     |
// +-----------------------------------------------------------------------+
// | file          : $RCSfile$
// | last update   : $Date$
// | last modifier : $Author$
// | revision      : $Revision$
// +-----------------------------------------------------------------------+
// | 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                                          |
// |                                                                       |
// | 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.                                                                  |
// +-----------------------------------------------------------------------+

/**
 * This file is included by category.php to show thumbnails for recent_cats
 * category
 * 
 */

// retrieving categories recently update, ie containing pictures added
// recently. The calculated table field categories.date_last will be
// easier to use
$query = '
SELECT id AS category_id
  FROM '.CATEGORIES_TABLE.'
  WHERE date_last > SUBDATE(CURRENT_DATE
                            ,INTERVAL '.$user['recent_period'].' DAY)';
if ( $user['forbidden_categories'] != '' )
{
  $query.= '
    AND id NOT IN ('.$user['forbidden_categories'].')';
}
$query.= '
;';
$result = pwg_query( $query );

// template thumbnail initialization
if (mysql_num_rows($result) > 0)
{
  $template->assign_block_vars('thumbnails', array());
  // first line
  $template->assign_block_vars('thumbnails.line', array());
  // current row displayed
  $row_number = 0;
}

// for each category, we have to search a recent picture to display and
// the name to display
while ( $row = mysql_fetch_array( $result ) )
{
  $cat_infos = get_cat_info( $row['category_id'] );
  $name = get_cat_display_name($cat_infos['name'],'<br />','',false);
  
  $query = '
SELECT id,file,tn_ext,storage_category_id
  FROM '.IMAGES_TABLE.', '.IMAGE_CATEGORY_TABLE.'
  WHERE category_id = '.$row['category_id'].'
    AND date_available > SUBDATE(CURRENT_DATE
                                 ,INTERVAL '.$user['recent_period'].' DAY)
    AND id = image_id
  ORDER BY RAND()
  LIMIT 0,1
;';
  $subrow = mysql_fetch_array( pwg_query( $query ) );

  $thumbnail_src = get_thumbnail_src($subrow['file'],
                                     $subrow['storage_category_id'],
                                     @$subrow['tn_ext']);
  
  $url_link = PHPWG_ROOT_PATH.'category.php?cat='.$row['category_id'];
  
  $template->assign_block_vars(
    'thumbnails.line.thumbnail',
    array(
      'IMAGE'                   => $thumbnail_src,
      'IMAGE_ALT'               => $subrow['file'],
      'IMAGE_TITLE'             => $lang['hint_category'],
      'IMAGE_NAME'              => '['.$name.']',
      'IMAGE_STYLE'             => 'thumb_category',
        
      'U_IMG_LINK'              => add_session_id( $url_link )
      )
    );
  $template->assign_block_vars('thumbnails.line.thumbnail.bullet',array());

  // create a new line ?
  if (++$row_number == $user['nb_image_line'])
  {
    $template->assign_block_vars('thumbnails.line', array());
    $row_number = 0;
  }
}
?>