Zeile 1 | Zeile 1 |
---|
<?php /** * MyBB 1.6
|
<?php /** * MyBB 1.6
|
* Copyright � 2010 MyBB Group, All Rights Reserved
| * Copyright 2010 MyBB Group, All Rights Reserved
|
* * Website: http://mybb.com * License: http://mybb.com/about/license *
|
* * Website: http://mybb.com * License: http://mybb.com/about/license *
|
* $Id: functions_indicators.php 4941 2010-05-15 18:17:38Z RyanGordon $
| * $Id: functions_indicators.php 5606 2011-09-19 13:38:50Z Tomm $
|
*/
/**
| */
/**
|
Zeile 75 | Zeile 75 |
---|
$comma = ','; } }
|
$comma = ','; } }
|
|
|
if(!empty($tids)) { $count = 0;
|
if(!empty($tids)) { $count = 0;
|
// We set a limit to 100 otherwise it'll become too processor intensive, especially if we have many threads. $query = $db->query(" SELECT lastpost, tid, fid FROM ".TABLE_PREFIX."threads WHERE visible=1 AND closed NOT LIKE 'moved|%' AND fid IN ($fid) AND tid IN ($tids) AND lastpost > '{$cutoff}' LIMIT 100 ");
| // We've read at least some threads, are they here? $query = $db->simple_select("threads", "lastpost, tid, fid", "visible=1 AND closed NOT LIKE 'moved|%' AND fid IN ($fid) AND lastpost > '{$cutoff}'", array("limit" => 100));
|
while($thread = $db->fetch_array($query)) { if($thread['lastpost'] > intval($threadsread[$thread['tid']]) && $thread['lastpost'] > intval($forumsread[$thread['fid']]))
| while($thread = $db->fetch_array($query)) { if($thread['lastpost'] > intval($threadsread[$thread['tid']]) && $thread['lastpost'] > intval($forumsread[$thread['fid']]))
|
Zeile 94 | Zeile 90 |
---|
++$count; } }
|
++$count; } }
|
|
|
return $count;
|
return $count;
|
} } else { switch($db->type) { case "pgsql": $query = $db->query(" SELECT COUNT(t.tid) AS unread_count FROM ".TABLE_PREFIX."threads t LEFT JOIN ".TABLE_PREFIX."threadsread tr ON (tr.tid=t.tid AND tr.uid='{$mybb->user['uid']}') LEFT JOIN ".TABLE_PREFIX."forumsread fr ON (fr.fid=t.fid AND fr.uid='{$mybb->user['uid']}')
| }
// Not read any threads? return false; } else { switch($db->type) { case "pgsql": $query = $db->query(" SELECT COUNT(t.tid) AS unread_count FROM ".TABLE_PREFIX."threads t LEFT JOIN ".TABLE_PREFIX."threadsread tr ON (tr.tid=t.tid AND tr.uid='{$mybb->user['uid']}') LEFT JOIN ".TABLE_PREFIX."forumsread fr ON (fr.fid=t.fid AND fr.uid='{$mybb->user['uid']}')
|
WHERE t.visible=1 AND t.closed NOT LIKE 'moved|%' AND t.fid IN ($fid) AND t.lastpost > COALESCE(tr.dateline,$cutoff) AND t.lastpost > COALESCE(fr.dateline,$cutoff) AND t.lastpost>$cutoff
|
WHERE t.visible=1 AND t.closed NOT LIKE 'moved|%' AND t.fid IN ($fid) AND t.lastpost > COALESCE(tr.dateline,$cutoff) AND t.lastpost > COALESCE(fr.dateline,$cutoff) AND t.lastpost>$cutoff
|
");
| ");
|
break; default: $query = $db->query("
| break; default: $query = $db->query("
|
Zeile 120 | Zeile 120 |
---|
"); } return $db->fetch_field($query, "unread_count");
|
"); } return $db->fetch_field($query, "unread_count");
|
} }
/**
| } }
/**
|
* Mark a particular forum as read. * * @param int The forum ID
| * Mark a particular forum as read. * * @param int The forum ID
|
Zeile 135 | Zeile 135 |
---|
// Can only do "true" tracking for registered users if($mybb->settings['threadreadcut'] > 0 && $mybb->user['uid']) {
|
// Can only do "true" tracking for registered users if($mybb->settings['threadreadcut'] > 0 && $mybb->user['uid']) {
|
| // Experimental setting to mark parent forums as read $forums_to_read = array();
if($mybb->settings['readparentforums']) { $ignored_forums = array(); $forums = array_reverse(explode(",", get_parent_list($fid)));
unset($forums[0]); if(!empty($forums)) { $ignored_forums[] = $fid;
foreach($forums as $forum) { $fids = array($forum); $ignored_forums[] = $forum;
$children = explode(",", get_parent_list($forum)); foreach($children as $child) { if(in_array($child, $ignored_forums)) { continue; }
$fids[] = $child; $ignored_forums[] = $child; }
if(fetch_unread_count(implode(",", $fids)) == 0) { $forums_to_read[] = $forum; } } } }
|
switch($db->type) { case "pgsql": case "sqlite": add_shutdown(array($db, "replace_query"), array("forumsread", array('fid' => $fid, 'uid' => $mybb->user['uid'], 'dateline' => TIME_NOW), array("fid", "uid")));
|
switch($db->type) { case "pgsql": case "sqlite": add_shutdown(array($db, "replace_query"), array("forumsread", array('fid' => $fid, 'uid' => $mybb->user['uid'], 'dateline' => TIME_NOW), array("fid", "uid")));
|
| if(!empty($forums_to_read)) { foreach($forums_to_read as $forum) { add_shutdown(array($db, "replace_query"), array("forumsread", array('fid' => $forum, 'uid' => $mybb->user['uid'], 'dateline' => TIME_NOW), array('fid', 'uid'))); } }
|
break; default:
|
break; default:
|
| $child_sql = ''; if(!empty($forums_to_read)) { foreach($forums_to_read as $forum) { $child_sql .= ", ('{$forum}', '{$mybb->user['uid']}', '".TIME_NOW."')"; } }
|
$db->shutdown_query(" REPLACE INTO ".TABLE_PREFIX."forumsread (fid, uid, dateline)
|
$db->shutdown_query(" REPLACE INTO ".TABLE_PREFIX."forumsread (fid, uid, dateline)
|
VALUES('{$fid}', '{$mybb->user['uid']}', '".TIME_NOW."')
| VALUES('{$fid}', '{$mybb->user['uid']}', '".TIME_NOW."'){$child_sql}
|
"); } }
| "); } }
|
Zeile 165 | Zeile 220 |
---|
// Can only do "true" tracking for registered users if($mybb->user['uid'] > 0)
|
// Can only do "true" tracking for registered users if($mybb->user['uid'] > 0)
|
{
| {
|
$db->update_query("users", array('lastvisit' => TIME_NOW), "uid='".$mybb->user['uid']."'"); require_once MYBB_ROOT."inc/functions_user.php"; update_pm_count('', 2);
| $db->update_query("users", array('lastvisit' => TIME_NOW), "uid='".$mybb->user['uid']."'"); require_once MYBB_ROOT."inc/functions_user.php"; update_pm_count('', 2);
|
Zeile 246 | Zeile 301 |
---|
} else {
|
} else {
|
| my_setcookie("mybb[readallforums]", 1);
|
my_setcookie("mybb[lastvisit]", TIME_NOW);
|
my_setcookie("mybb[lastvisit]", TIME_NOW);
|
|
|
my_unsetcookie("mybb[threadread]"); my_unsetcookie("mybb[forumread]"); }
| my_unsetcookie("mybb[threadread]"); my_unsetcookie("mybb[forumread]"); }
|