Forum
load("forumdisplay"); $plugins->run_hooks("forumdisplay_start"); $fid = intval($mybb->input['fid']); if($fid < 0) { switch($fid) { case "-1": $location = "index.php"; break; case "-2": $location = "search.php"; break; case "-3": $location = "usercp.php"; break; case "-4": $location = "private.php"; break; case "-5": $location = "online.php"; break; } if($location) { header("Location: ".$location); exit; } } // Get forum info $foruminfo = get_forum($fid); if(!$foruminfo) { error($lang->error_invalidforum); } $archive_url = build_archive_link("forum", $fid); $currentitem = $fid; build_forum_breadcrumb($fid); $parentlist = $foruminfo['parentlist']; // To validate, turn & to & but support unicode $foruminfo['name'] = preg_replace("#&(?!#[0-9]+;)#si", "&", $foruminfo['name']); $forumpermissions = forum_permissions(); $fpermissions = $forumpermissions[$fid]; if($fpermissions['canview'] != 1) { error_no_permission(); } if($mybb->user['uid'] == 0) { // Cookie'd forum read time $forumsread = unserialize($mybb->cookies['mybb']['forumread']); if(!is_array($forumsread)) { if($mybb->cookies['mybb']['readallforums']) { $forumsread[$fid] = $mybb->cookies['mybb']['lastvisit']; } else { $forumsread = array(); } } $query = $db->simple_select("forums", "*", "active != 0", array("order_by" => "pid, disporder")); } else { // Build a forum cache from the database $query = $db->query(" SELECT f.*, fr.dateline AS lastread FROM ".TABLE_PREFIX."forums f LEFT JOIN ".TABLE_PREFIX."forumsread fr ON (fr.fid=f.fid AND fr.uid='{$mybb->user['uid']}') WHERE f.active != 0 ORDER BY pid, disporder "); } while($forum = $db->fetch_array($query)) { if($mybb->user['uid'] == 0 && $forumsread[$forum['fid']]) { $forum['lastread'] = $forumsread[$forum['fid']]; } $fcache[$forum['pid']][$forum['disporder']][$forum['fid']] = $forum; } // Get the forum moderators if the setting is enabled. if($mybb->settings['modlist'] != 0) { $moderatorcache = $cache->read("moderators"); } $bgcolor = "trow1"; if($mybb->settings['subforumsindex'] != 0) { $showdepth = 3; } else { $showdepth = 2; } $child_forums = build_forumbits($fid, 2); $forums = $child_forums['forum_list']; if($forums) { $lang->sub_forums_in = $lang->sprintf($lang->sub_forums_in, $foruminfo['name']); eval("$subforums = "".$templates->get("forumdisplay_subforums")."";"); } $excols = "forumdisplay"; // Password protected forums check_forum_password($foruminfo['fid']); if($foruminfo['linkto']) { header("Location: {$foruminfo['linkto']}"); exit; } // Make forum jump... if($mybb->settings['enableforumjump'] != 0) { $forumjump = build_forum_jump("", $fid, 1); } if($foruminfo['type'] == "f" && $foruminfo['open'] != 0) { eval("$newthread = "".$templates->get("forumdisplay_newthread")."";"); } if($fpermissions['cansearch'] != 0 && $foruminfo['type'] == "f") { eval("$searchforum = "".$templates->get("forumdisplay_searchforum")."";"); } $done_moderators = array( "users" => array(), "groups" => array() ); $moderators = ''; $parentlistexploded = explode(",", $parentlist); foreach($parentlistexploded as $mfid) { // This forum has moderators if(is_array($moderatorcache[$mfid])) { // Fetch each moderator from the cache and format it, appending it to the list foreach($moderatorcache[$mfid] as $modtype) { foreach($modtype as $moderator) { if($moderator['isgroup']) { if(in_array($moderator['id'], $done_moderators['groups'])) { continue; } $moderators .= $comma.htmlspecialchars_uni($moderator['title']); $done_moderators['groups'][] = $moderator['id']; } else { if(in_array($moderator['id'], $done_moderators['users'])) { continue; } $moderators .= "{$comma}".format_name(htmlspecialchars_uni($moderator['username']), $moderator['usergroup'], $moderator['displaygroup']).""; $done_moderators['users'][] = $moderator['id']; } $comma = $lang->comma; } } } } $comma = ''; // If we have a moderators list, load the template if($moderators) { eval("$moderatedby = "".$templates->get("forumdisplay_moderatedby")."";"); } else { $moderatedby = ''; } // Get the users browsing this forum. if($mybb->settings['browsingthisforum'] != 0) { $timecut = TIME_NOW - $mybb->settings['wolcutoff']; $comma = ''; $guestcount = 0; $membercount = 0; $inviscount = 0; $onlinemembers = ''; $query = $db->query(" SELECT s.ip, s.uid, u.username, s.time, u.invisible, u.usergroup, u.usergroup, u.displaygroup FROM ".TABLE_PREFIX."sessions s LEFT JOIN ".TABLE_PREFIX."users u ON (s.uid=u.uid) WHERE s.time > '$timecut' AND location1='$fid' AND nopermission != 1 ORDER BY u.username ASC, s.time DESC "); while($user = $db->fetch_array($query)) { if($user['uid'] == 0) { ++$guestcount; } else { if($doneusers[$user['uid']] < $user['time'] || !$doneusers[$user['uid']]) { $doneusers[$user['uid']] = $user['time']; ++$membercount; if($user['invisible'] == 1) { $invisiblemark = "*"; ++$inviscount; } else { $invisiblemark = ''; } if($user['invisible'] != 1 || $mybb->usergroup['canviewwolinvis'] == 1 || $user['uid'] == $mybb->user['uid']) { $user['username'] = format_name($user['username'], $user['usergroup'], $user['displaygroup']); $user['profilelink'] = build_profile_link($user['username'], $user['uid']); eval("$onlinemembers .= "".$templates->get("forumdisplay_usersbrowsing_user", 1, 0)."";"); $comma = $lang->comma; } } } } if($guestcount) { $guestsonline = $lang->sprintf($lang->users_browsing_forum_guests, $guestcount); } if($guestcount && $onlinemembers) { $onlinesep = $lang->comma; } $invisonline = ''; if($inviscount && $mybb->usergroup['canviewwolinvis'] != 1 && ($inviscount != 1 && $mybb->user['invisible'] != 1)) { $invisonline = $lang->sprintf($lang->users_browsing_forum_invis, $inviscount); } if($invisonline != '' && $guestcount) { $onlinesep2 = $lang->comma; } eval("$usersbrowsing = "".$templates->get("forumdisplay_usersbrowsing")."";"); } // Do we have any forum rules to show for this forum? $forumrules = ''; if($foruminfo['rulestype'] != 0 && $foruminfo['rules']) { if(!$foruminfo['rulestitle']) { $foruminfo['rulestitle'] = $lang->sprintf($lang->forum_rules, $foruminfo['name']); } $rules_parser = array( "allow_html" => 1, "allow_mycode" => 1, "allow_smilies" => 1, "allow_imgcode" => 1 ); $foruminfo['rules'] = $parser->parse_message($foruminfo['rules'], $rules_parser); if($foruminfo['rulestype'] == 1) { eval("$rules = "".$templates->get("forumdisplay_rules")."";"); } else if($foruminfo['rulestype'] == 2) { eval("$rules = "".$templates->get("forumdisplay_rules_link")."";"); } } $bgcolor = "trow1"; // Set here to fetch only approved topics (and then below for a moderator we change this). $visibleonly = "AND visible='1'"; $tvisibleonly = "AND t.visible='1'"; // Check if the active user is a moderator and get the inline moderation tools. if(is_moderator($fid)) { eval("$inlinemodcol = "".$templates->get("forumdisplay_inlinemoderation_col")."";"); $ismod = true; $inlinecount = "0"; $inlinecookie = "inlinemod_forum".$fid; $visibleonly = " AND (visible='1' OR visible='0')"; $tvisibleonly = " AND (t.visible='1' OR t.visible='0')"; } else { $inlinemod = ''; $ismod = false; } if(is_moderator($fid, "caneditposts") || $fpermissions['caneditposts'] == 1) { $can_edit_titles = 1; } else { $can_edit_titles = 0; } unset($rating); // Pick out some sorting options. // First, the date cut for the threads. $datecut = 0; if(!$mybb->input['datecut']) { // If the user manually set a date cut, use it. if($mybb->user['daysprune']) { $datecut = $mybb->user['daysprune']; } else { // If the forum has a non-default date cut, use it. if(!empty($foruminfo['defaultdatecut'])) { $datecut = $foruminfo['defaultdatecut']; } } } // If there was a manual date cut override, use it. else { $datecut = intval($mybb->input['datecut']); } $datecut = intval($datecut); $datecutsel[$datecut] = "selected="selected""; if($datecut > 0 && $datecut != 9999) { $checkdate = TIME_NOW - ($datecut * 86400); $datecutsql = "AND (lastpost >= '$checkdate' OR sticky = '1')"; $datecutsql2 = "AND (t.lastpost >= '$checkdate' OR t.sticky = '1')"; } else { $datecutsql = ''; $datecutsql2 = ''; } // Pick the sort order. if(!isset($mybb->input['order']) && !empty($foruminfo['defaultsortorder'])) { $mybb->input['order'] = $foruminfo['defaultsortorder']; } $mybb->input['order'] = htmlspecialchars($mybb->input['order']); switch(my_strtolower($mybb->input['order'])) { case "asc": $sortordernow = "asc"; $ordersel['asc'] = "selected="selected""; $oppsort = $lang->desc; $oppsortnext = "desc"; break; default: $sortordernow = "desc"; $ordersel['desc'] = "selected="selected""; $oppsort = $lang->asc; $oppsortnext = "asc"; break; } // Sort by which field? if(!isset($mybb->input['sortby']) && !empty($foruminfo['defaultsortby'])) { $mybb->input['sortby'] = $foruminfo['defaultsortby']; } $t = "t."; $sortby = htmlspecialchars($mybb->input['sortby']); switch($mybb->input['sortby']) { case "subject": $sortfield = "subject"; break; case "replies": $sortfield = "replies"; break; case "views": $sortfield = "views"; break; case "starter": $sortfield = "username"; break; case "rating": $t = ""; $sortfield = "averagerating"; $sortfield2 = ", t.totalratings DESC"; break; case "started": $sortfield = "dateline"; break; default: $sortby = "lastpost"; $sortfield = "lastpost"; $mybb->input['sortby'] = "lastpost"; break; } $sortsel[$mybb->input['sortby']] = "selected="selected""; // Pick the right string to join the sort URL if($mybb->settings['seourls'] == "yes" || ($mybb->settings['seourls'] == "auto" && $_SERVER['SEO_SUPPORT'] == 1)) { $string = "?"; } else { $string = "&"; } // Are we viewing a specific page? if(isset($mybb->input['page']) && is_numeric($mybb->input['page'])) { $sorturl = get_forum_link($fid, $mybb->input['page']).$string."datecut=$datecut"; } else { $sorturl = get_forum_link($fid).$string."datecut=$datecut"; } eval("$orderarrow['$sortby'] = "".$templates->get("forumdisplay_orderarrow")."";"); $threadcount = 0; $useronly = $tuseronly = ""; if($fpermissions['canonlyviewownthreads'] == 1) { $useronly = "AND uid={$mybb->user['uid']}"; $tuseronly = "AND t.uid={$mybb->user['uid']}"; } if($fpermissions['canviewthreads'] != 0) { // How many posts are there? if($datecut > 0 || $fpermissions['canonlyviewownthreads'] == 1) { $query = $db->simple_select("threads", "COUNT(tid) AS threads", "fid = '$fid' $useronly $visibleonly $datecutsql"); $threadcount = $db->fetch_field($query, "threads"); } else { $query = $db->simple_select("forums", "threads, unapprovedthreads", "fid = '{$fid}'", array('limit' => 1)); $forum_threads = $db->fetch_array($query); $threadcount = $forum_threads['threads']; if($ismod == true) { $threadcount += $forum_threads['unapprovedthreads']; } // If we have 0 threads double check there aren't any "moved" threads if($threadcount == 0) { $query = $db->simple_select("threads", "COUNT(tid) AS threads", "fid = '$fid' $useronly $visibleonly", array('limit' => 1)); $threadcount = $db->fetch_field($query, "threads"); } } } // How many pages are there? if(!$mybb->settings['threadsperpage']) { $mybb->settings['threadsperpage'] = 20; } $perpage = $mybb->settings['threadsperpage']; if(intval($mybb->input['page']) > 0) { $page = intval($mybb->input['page']); $start = ($page-1) * $perpage; $pages = $threadcount / $perpage; $pages = ceil($pages); if($page > $pages || $page <= 0) { $start = 0; $page = 1; } } else { $start = 0; $page = 1; } $end = $start + $perpage; $lower = $start + 1; $upper = $end; if($upper > $threadcount) { $upper = $threadcount; } // Assemble page URL if($mybb->input['sortby'] || $mybb->input['order'] || $mybb->input['datecut']) // Ugly URL { $page_url = str_replace("{fid}", $fid, FORUM_URL_PAGED); if($mybb->settings['seourls'] == "yes" || ($mybb->settings['seourls'] == "auto" && $_SERVER['SEO_SUPPORT'] == 1)) { $q = "?"; $and = ''; } else { $q = ''; $and = "&"; } if($sortby != "lastpost") { $page_url .= "{$q}{$and}sortby={$sortby}"; $q = ''; $and = "&"; } if($sortordernow != "desc") { $page_url .= "{$q}{$and}order={$sortordernow}"; $q = ''; $and = "&"; } if($datecut > 0) { $page_url .= "{$q}{$and}datecut={$datecut}"; } } else { $page_url = str_replace("{fid}", $fid, FORUM_URL_PAGED); } $multipage = multipage($threadcount, $perpage, $page, $page_url); if($foruminfo['allowtratings'] != 0 && $fpermissions['canviewthreads'] != 0) { $lang->load("ratethread"); switch($db->type) { case "pgsql": $ratingadd = "CASE WHEN t.numratings=0 THEN 0 ELSE t.totalratings/t.numratings::numeric END AS averagerating, "; break; default: $ratingadd = "(t.totalratings/t.numratings) AS averagerating, "; } $lpbackground = "trow2"; eval("$ratingcol = "".$templates->get("forumdisplay_threadlist_rating")."";"); eval("$ratingsort = "".$templates->get("forumdisplay_threadlist_sortrating")."";"); $colspan = "7"; } else { if($sortfield == "averagerating") { $t = "t."; $sortfield = "lastpost"; } $ratingadd = ''; $lpbackground = "trow1"; $colspan = "6"; } if($ismod) { ++$colspan; } // Get Announcements $forum_stats = $cache->read("forumsdisplay"); if($forum_stats[-1]['announcements'] || $forum_stats[$fid]['announcements']) { $limit = ''; $announcements = ''; if($mybb->settings['announcementlimit']) { $limit = "LIMIT 0, ".$mybb->settings['announcementlimit']; } $sql = build_parent_list($fid, "fid", "OR", $parentlist); $time = TIME_NOW; $query = $db->query(" SELECT a.*, u.username FROM ".TABLE_PREFIX."announcements a LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=a.uid) WHERE a.startdate<='$time' AND (a.enddate>='$time' OR a.enddate='0') AND ($sql OR fid='-1') ORDER BY a.startdate DESC $limit "); $bgcolor = alt_trow(true); // Reset the trow colors while($announcement = $db->fetch_array($query)) { if($announcement['startdate'] > $mybb->user['lastvisit']) { $new_class = ' class="subject_new"'; $folder = "newfolder"; } else { $new_class = ' class="subject_old"'; $folder = "folder"; } $announcement['announcementlink'] = get_announcement_link($announcement['aid']); $announcement['subject'] = $parser->parse_badwords($announcement['subject']); $announcement['subject'] = htmlspecialchars_uni($announcement['subject']); $postdate = my_date($mybb->settings['dateformat'], $announcement['startdate']); $posttime = my_date($mybb->settings['timeformat'], $announcement['startdate']); $announcement['profilelink'] = build_profile_link($announcement['username'], $announcement['uid']); if($foruminfo['allowtratings'] != 0 && $fpermissions['canviewthreads'] != 0) { eval("$rating = "".$templates->get("forumdisplay_announcement_rating")."";"); $lpbackground = "trow2"; } else { $rating = ''; $lpbackground = "trow1"; } if($ismod) { eval("$modann = "".$templates->get("forumdisplay_announcements_announcement_modbit")."";"); } else { $modann = ''; } $plugins->run_hooks("forumdisplay_announcement"); eval("$announcements .= "".$templates->get("forumdisplay_announcements_announcement")."";"); $bgcolor = alt_trow(); } if($announcements) { eval("$announcementlist = "".$templates->get("forumdisplay_announcements")."";"); $shownormalsep = true; } } $icon_cache = $cache->read("posticons"); if($fpermissions['canviewthreads'] != 0) { // Start Getting Threads $query = $db->query(" SELECT t.*, {$ratingadd}t.username AS threadusername, u.username FROM ".TABLE_PREFIX."threads t LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid = t.uid) WHERE t.fid='$fid' $tuseronly $tvisibleonly $datecutsql2 ORDER BY t.sticky DESC, {$t}{$sortfield} $sortordernow $sortfield2 LIMIT $start, $perpage "); $ratings = false; while($thread = $db->fetch_array($query)) { $threadcache[$thread['tid']] = $thread; if($thread['numratings'] > 0 && $ratings == false) { $ratings = true; // Looks for ratings in the forum } // If this is a moved thread - set the tid for participation marking and thread read marking to that of the moved thread if(substr($thread['closed'], 0, 5) == "moved") { $tid = substr($thread['closed'], 6); if(!$tids[$tid]) { $moved_threads[$tid] = $thread['tid']; $tids[$thread['tid']] = $tid; } } // Otherwise - set it to the plain thread ID else { $tids[$thread['tid']] = $thread['tid']; if($moved_threads[$tid]) { unset($moved_threads[$tid]); } } } if($foruminfo['allowtratings'] != 0 && $mybb->user['uid'] && $tids && $ratings == true) { // Check if we've rated threads on this page // Guests get the pleasure of not being ID'd, but will be checked when they try and rate $imp = implode(",", $tids); $query = $db->simple_select("threadratings", "tid, uid", "tid IN ({$imp}) AND uid = '{$mybb->user['uid']}'"); while($rating = $db->fetch_array($query)) { $threadcache[$rating['tid']]['rated'] = 1; } } } else { $threadcache = $tids = null; } // If user has moderation tools available, prepare the Select All feature $num_results = $db->num_rows($query); if(is_moderator($fid) && $num_results > 0) { $lang->page_selected = $lang->sprintf($lang->page_selected, intval($num_results)); $lang->select_all = $lang->sprintf($lang->select_all, intval($threadcount)); $lang->all_selected = $lang->sprintf($lang->all_selected, intval($threadcount)); eval("$selectall = "".$templates->get("forumdisplay_inlinemoderation_selectall")."";"); } if($tids) { $tids = implode(",", $tids); } // Check participation by the current user in any of these threads - for 'dot' folder icons if($mybb->settings['dotfolders'] != 0 && $mybb->user['uid'] && $threadcache) { $query = $db->simple_select("posts", "tid,uid", "uid='{$mybb->user['uid']}' AND tid IN ({$tids}) {$visibleonly}"); while($post = $db->fetch_array($query)) { if($moved_threads[$post['tid']]) { $post['tid'] = $moved_threads[$post['tid']]; } if($threadcache[$post['tid']]) { $threadcache[$post['tid']]['doticon'] = 1; } } } // Read threads if($mybb->user['uid'] && $mybb->settings['threadreadcut'] > 0 && $threadcache) { $query = $db->simple_select("threadsread", "*", "uid='{$mybb->user['uid']}' AND tid IN ({$tids})"); while($readthread = $db->fetch_array($query)) { if($moved_threads[$readthread['tid']]) { $readthread['tid'] = $moved_threads[$readthread['tid']]; } if($threadcache[$readthread['tid']]) { $threadcache[$readthread['tid']]['lastread'] = $readthread['dateline']; } } } if($mybb->settings['threadreadcut'] > 0 && $mybb->user['uid']) { $query = $db->simple_select("forumsread", "dateline", "fid='{$fid}' AND uid='{$mybb->user['uid']}'"); $forum_read = $db->fetch_field($query, "dateline"); $read_cutoff = TIME_NOW-$mybb->settings['threadreadcut']*60*60*24; if($forum_read == 0 || $forum_read < $read_cutoff) { $forum_read = $read_cutoff; } } else { $forum_read = my_get_array_cookie("forumread", $fid); if($mybb->cookies['mybb']['readallforums'] && !$forum_read) { $forum_read = $mybb->cookies['mybb']['lastvisit']; } } $unreadpost = 0; $threads = ''; $load_inline_edit_js = 0; if(is_array($threadcache)) { foreach($threadcache as $thread) { $plugins->run_hooks("forumdisplay_thread"); $moved = explode("|", $thread['closed']); if($thread['visible'] == 0) { $bgcolor = "trow_shaded"; } else { $bgcolor = alt_trow(); } if($thread['sticky'] == 1) { $thread_type_class = " forumdisplay_sticky"; } else { $thread_type_class = " forumdisplay_regular"; } $folder = ''; $prefix = ''; $thread['author'] = $thread['uid']; if(!$thread['username']) { $thread['username'] = $thread['threadusername']; $thread['profilelink'] = $thread['threadusername']; } else { $thread['profilelink'] = build_profile_link($thread['username'], $thread['uid']); } // If this thread has a prefix, insert a space between prefix and subject $threadprefix = ''; if($thread['prefix'] != 0) { $threadprefix = build_prefixes($thread['prefix']); $thread['threadprefix'] = $threadprefix['displaystyle'].' '; } $thread['subject'] = $parser->parse_badwords($thread['subject']); $thread['subject'] = htmlspecialchars_uni($thread['subject']); if($thread['icon'] > 0 && $icon_cache[$thread['icon']]) { $icon = $icon_cache[$thread['icon']]; $icon = ""; } else { $icon = " "; } $prefix = ''; if($thread['poll']) { $prefix = $lang->poll_prefix; } if($thread['sticky'] == "1" && !$donestickysep) { eval("$threads .= "".$templates->get("forumdisplay_sticky_sep")."";"); $shownormalsep = true; $donestickysep = true; } else if($thread['sticky'] == 0 && $shownormalsep) { eval("$threads .= "".$templates->get("forumdisplay_threads_sep")."";"); $shownormalsep = false; } $rating = ''; if($foruminfo['allowtratings'] != 0) { if($moved[0] == "moved") { $rating = "
Forum - Örnek forum
Burdasın: Forum => Örnek forum |
|
Konu | Postalar | Son kayıt: |
Örnek konu | 1 | Benjamin Lochmann 27.08.2011, 19:23 (UTC) |
Yeni konu aç:
Bütün konular: 1
Bütün postalar: 1
Bütün kullanıcılar: 1