2 /************************************************************************/
4 /************************************************************************/
5 /* Copyright (c) 2002-2007 by Greg Gay, Joel Kronenberg & Heidi Hazelton*/
6 /* Adaptive Technology Resource Centre / University of Toronto */
9 /* This program is free software. You can redistribute it and/or */
10 /* modify it under the terms of the GNU General Public License */
11 /* as published by the Free Software Foundation. */
12 /************************************************************************/
13 if (!defined('AT_INCLUDE_PATH')) { exit; }
15 $sql = "SELECT COUNT(*) AS cnt FROM ".TABLE_PREFIX."forums_threads WHERE parent_id=0 AND forum_id=$fid";
16 $result = mysql_query($sql, $db);
17 $num_threads = mysql_fetch_assoc($result);
18 $num_threads = $num_threads['cnt'];
24 $page = intval($_GET['page']);
26 $start = ($page-1)*$num_per_page;
27 $num_pages = ceil($num_threads/$num_per_page);
29 $page_string = SEP.'fid='. $fid;
31 $orders = array('asc' => 'desc', 'desc' => 'asc');
32 $cols = array('subject' => 1, 'num_comments' => 1, 'login' => 1, 'last_comment' => 1);
34 if (isset($_GET['asc'])) {
36 $col = isset($cols[$_GET['asc']]) ? $_GET['asc'] : 'last_comment';
37 } else if (isset($_GET['desc'])) {
39 $col = isset($cols[$_GET['desc']]) ? $_GET['desc'] : 'last_comment';
43 $col = 'last_comment';
46 $sql = "SELECT *, last_comment + 0 AS stamp, DATE_FORMAT(last_comment, '%Y-%m-%d %H-%i:%s') AS last_comment FROM ".TABLE_PREFIX."forums_threads WHERE parent_id=0 AND forum_id=$fid AND member_id>0 ORDER BY sticky DESC, $col $order LIMIT $start,$num_per_page";
47 $result = mysql_query($sql, $db);
49 if (!($row = mysql_fetch_assoc($result))) {
50 $msg->printInfos('NO_POSTS_FOUND');
54 <table class="data static" summary="" rules="rows">
56 <?php if ($col == 'subject'): ?>
59 <?php elseif($col == 'num_comments'): ?>
63 <?php elseif($col == 'login'): ?>
67 <?php elseif($col == 'last_comment'): ?>
75 <th scope="col"><a href="forum/index.php?<?php echo $orders[$order]; ?>=subject<?php echo $page_string; ?>"><?php echo _AT('topic'); ?></a></th>
76 <th scope="col"><a href="forum/index.php?<?php echo $orders[$order]; ?>=num_comments<?php echo $page_string; ?>"><?php echo _AT('replies'); ?></a></th>
77 <th scope="col"><a href="forum/index.php?<?php echo $orders[$order]; ?>=login<?php echo $page_string; ?>"><?php echo _AT('started_by'); ?></a></th>
78 <th scope="col"><a href="forum/index.php?<?php echo $orders[$order]; ?>=last_comment<?php echo $page_string; ?>"><?php echo _AT('last_comment'); ?></a></th>
81 if (authenticate(AT_PRIV_FORUMS, AT_PRIV_RETURN)) {
82 echo '<th class="cat"> </th>';
90 echo '<td style="background-image: none" colspan="'.$colspan.'" align="right">'._AT('page').': ';
92 for ($i=1; $i<=$num_pages; $i++) {
96 echo '<a href="'.$_SERVER['PHP_SELF'].'?fid='.$fid.SEP.'page='.$i.'">'.$i.'</a>';
100 echo ' <span class="spacer">|</span> ';
109 $current_thread = $row['thread_id'];
111 $row['subject'] = AT_print($row['subject'], 'forums_threads.subject');
113 /* crop the subject, if needed */
114 if (strlen($row['subject']) > 28) {
115 $row['subject'] = substr($row['subject'], 0, 25).'...';
120 if ($_SESSION['valid_user']) {
121 if ($row['stamp'] > $last_accessed[$row['post_id']]['last_accessed']) {
122 echo '<i style="color: green; font-weight: bold; font-size: .7em;" title="'._AT('new_thread').'">'._AT('new').'</i> ';
126 if ($row['num_comments'] > 10) {
127 echo '<em style="color: red; font-weight: bold; font-size: .7em;" title="'._AT('hot_thread').'">'._AT('hot').'</em> ';
130 if ($row['locked'] != 0) {
131 echo '<img src="images/topic_lock.gif" alt="'._AT('thread_locked').'" class="menuimage3" title="'._AT('thread_locked').'" /> ';
134 if ($row['sticky'] != 0) {
135 echo '<img src="images/forum/topic_stick.gif" alt="'._AT('sticky_thread').'" class="menuimage3" title="'._AT('sticky_thread').'" /> ';
138 if ($row['locked'] != 1) {
139 echo '<a href="forum/view.php?fid='.$fid.SEP.'pid='.$row['post_id'].'">'.$row['subject'].'</a>';
141 if ($row['locked'] == 2) {
142 echo ' <i class="spacer">('._AT('post_lock').')</i>';
145 echo $row['subject'].' <i class="spacer">('._AT('read_lock').')</i>';
148 /* print page numbers */
149 $num_pages_2 = ceil(($row['num_comments']+1)/$num_per_page);
151 if ($num_pages_2 > 1) {
152 echo ' <small class="spacer">( Page: ';
153 for ($i=2; $i<=$num_pages_2; $i++) {
154 echo '<a href="forum/view.php?fid='.$fid.SEP.'pid='.$row['post_id'].SEP.'page='.$i.'">'.$i.'</a>';
156 if ($i<$num_pages_2){
162 if ($_SESSION['enroll'] && !$row['locked']) {
163 if (isset($last_accessed[$row['post_id']]) && $last_accessed[$row['post_id']]['subscribe']){
164 echo ' <br /><small><a href="forum/subscribe.php?us=1'.SEP.'pid='.$row['post_id'].SEP.'fid='.$fid.SEP.'t=1">('._AT('unsubscribe1').')</a></small>';
166 echo ' <br /><small><a href="forum/subscribe.php?pid='.$row['post_id'].SEP.'fid='.$fid.SEP.'t=1">('._AT('subscribe1').')</a></small>';
171 echo '<td width="10%" align="center">'.$row['num_comments'].'</td>';
173 echo '<td width="10%"><a href="'.AT_BASE_HREF.'profile.php?id='.$row['member_id'].'">'.get_display_name($row['member_id']).'</a></td>';
175 echo '<td width="20%" align="right" nowrap="nowrap">';
176 echo AT_date(_AT('forum_date_format'), $row['last_comment'], AT_DATE_MYSQL_DATETIME);
179 if (authenticate(AT_PRIV_FORUMS, AT_PRIV_RETURN)) {
180 echo '<td nowrap="nowrap">';
181 echo ' <a href="forum/stick.php?fid='.$fid.SEP.'pid='.$row['post_id'].'"><img src="images/forum/sticky.gif" border="0" alt="'._AT('sticky_thread').'" title="'._AT('sticky_thread').'" /></a> ';
183 if ($row['locked'] != 0) {
184 echo '<a href="forum/lock_thread.php?fid='.$fid.SEP.'pid='.$row['post_id'].SEP.'unlock='.$row['locked'].'"><img src="images/unlock.gif" border="0" alt="'._AT('unlock_thread').'" title="'._AT('unlock_thread').'"/></a>';
186 echo '<a href="forum/lock_thread.php?fid='.$fid.SEP.'pid='.$row['post_id'].'"><img src="images/lock.gif" border="0" alt="'._AT('lock_thread').'" title="'._AT('lock_thread').'"/></a>';
188 echo ' <a href="forum/move_thread.php?fid='.$fid.SEP.'pid='.$row['post_id'].SEP.'ppid=0"><img src="images/forum/move.gif" border="0" alt="'._AT('move_thread').'" title="'._AT('move_thread').'"/></a>';
190 echo ' <a href="forum/delete_thread.php?fid='.$fid.SEP.'pid='.$row['post_id'].SEP.'ppid=0"><img src="images/icon_delete.gif" border="0" alt="'._AT('delete_thread').'" title="'._AT('delete_thread').'"/></a>';
196 } while ($row = mysql_fetch_assoc($result));