Update api_comment.php
[bugdar.git] / index.php
1 <?php
2 /*=====================================================================*\
3 || ###################################################################
4 || # Bugdar
5 || # Copyright ©2002-2007 Blue Static
6 || #
7 || # This program is free software; you can redistribute it and/or modify
8 || # it under the terms of the GNU General Public License as published by
9 || # the Free Software Foundation; version 2 of the License.
10 || #
11 || # This program is distributed in the hope that it will be useful, but
12 || # WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13 || # or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 || # more details.
15 || #
16 || # You should have received a copy of the GNU General Public License along
17 || # with this program; if not, write to the Free Software Foundation, Inc.,
18 || # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
19 || ###################################################################
20 \*=====================================================================*/
21
22 $fetchtemplates = array(
23 'trackerhome',
24 'trackerhome_bits',
25 'list_head',
26 'pagenav',
27 'pagenav_bit'
28 );
29
30 define('SVN', '$Id$');
31
32 $focus['index'] = 'focus';
33
34 require_once('./global.php');
35 require_once('./includes/class_sort.php');
36
37 if (!can_perform('canviewbugs'))
38 {
39 $message->errorPermission();
40 }
41
42 $sort = new ListSorter('index');
43
44 require_once 'includes/pagination.php';
45 $pagination = new Pagination();
46 $pagination->processIncomingData();
47
48 // ###################################################################
49
50 $count = $db->queryFirst("
51 SELECT COUNT(*) AS count
52 FROM " . TABLE_PREFIX . "bug
53 WHERE (!hidden OR (hidden AND product IN (" . fetch_on_bits('canviewhidden') . "))" . (can_perform('canviewownhidden') ? " OR (hidden AND userid = " . bugdar::$userinfo['userid'] . " AND product IN (" . fetch_on_bits('canviewownhidden') . "))" : "") . ")
54 AND product IN (" . fetch_on_bits('canviewbugs') . ")" . ((bugdar::$options['hidestatuses'] OR isset(bugdar::$userinfo['hidestatuses'])) ? "
55 AND status NOT IN (" . (bugdar::$userinfo['hidestatuses'] != '' ? bugdar::$userinfo['hidestatuses'] : bugdar::$options['hidestatuses']) . ")" : "")
56 );
57
58 if (!$count['count'])
59 {
60 $message->error(T('There are no bugs to display. This could be because you do not have permission to view bugs, or there may be none in the database.'));
61 }
62
63 $pagination->setTotal($count['count']);
64 $pagination->splitPages();
65
66 $bugs_fetch = $db->query($sort->fetch_sql_query(null, $pagination->fetchLimit($pagination->getPage() - 1) . ", " . $pagination->getPerPage()));
67
68 foreach ($bugs_fetch as $bug)
69 {
70 BSFunctions::swap_css_classes('altcolor', '');
71 $bug = ProcessBugDataForDisplay($bug, BSFunctions::$cssClass);
72 $bugs .= $sort->constructRow($bug);
73 }
74
75 $bugs_fetch->free();
76
77 $columnHeads = $sort->constructColumnHeaders(true, 'p=' . $pagination->page . '&amp;pp=' . $pagination->perpage);
78 $show['pagenav'] = ($pagination->getPageCount() > 1);
79
80 $tpl = new BSTemplate('trackerhome');
81 $tpl->vars = array(
82 'columnHeads' => $columnHeads,
83 'bugs' => $bugs,
84 'pagenav' => $pagination->constructPageNav($sort->fetch_sort_link($sort->sortkey))
85 );
86 $tpl->evaluate()->flush();
87
88 /*=====================================================================*\
89 || ###################################################################
90 || # $HeadURL$
91 || # $Id$
92 || ###################################################################
93 \*=====================================================================*/
94 ?>