<?php
/*
 * Plugin Name: Advanced Sidebox for MyBB 1.6.x
 * Copyright 2014 WildcardSearch
 * http://www.rantcentralforums.com
 *
 * ASB default module
 */
// Include a check for Advanced Sidebox
if(!defined("IN_MYBB") || !defined("IN_ASB"))
{
    die("Direct initialization of this file is not allowed.<br /><br />Please make sure IN_MYBB is defined.");
}
/*
 * asb_latest_threads_info()
 *
 * provide info to ASB about the addon
 *
 * @return: (array) the module info
 */
function asb_latest_threads_info()
{
    global $lang;
    if(!$lang->asb_addon)
    {
        $lang->load('asb_addon');
    }
    return array(
        "title" => $lang->asb_latest_threads,
        "description" => $lang->asb_latest_threads_desc,
        "version" => "1.1",
        "wrap_content" => true,
        "xmlhttp" => true,
        "settings" => array(
            "max_threads" => array(
                "sid" => "NULL",
                "name" => "max_threads",
                "title" => $lang->asb_max_threads_title,
                "description" => $lang->asb_max_threads_desc,
                "optionscode" => "text",
                "value" => '20'
            ),
            "forum_show_list" => array(
                "sid" => "NULL",
                "name" => "forum_show_list",
                "title" => $lang->asb_forum_show_list_title,
                "description" => $lang->asb_forum_show_list_desc,
                "optionscode" => "text",
                "value" => ''
            ),
            "forum_hide_list" => array(
                "sid" => "NULL",
                "name" => "forum_hide_list",
                "title" => $lang->asb_forum_hide_list_title,
                "description" => $lang->asb_forum_hide_list_desc,
                "optionscode" => "text",
                "value" => ''
            ),
            "thread_show_list" => array(
                "sid" => "NULL",
                "name" => "thread_show_list",
                "title" => $lang->asb_thread_show_list_title,
                "description" => $lang->asb_thread_show_list_desc,
                "optionscode" => "text",
                "value" => ''
            ),
            "thread_hide_list" => array(
                "sid" => "NULL",
                "name" => "thread_hide_list",
                "title" => $lang->asb_thread_hide_list_title,
                "description" => $lang->asb_thread_hide_list_desc,
                "optionscode" => "text",
                "value" => ''
            ),
            "last_poster_avatar" => array(
                "sid" => "NULL",
                "name" => "last_poster_avatar",
                "title" => $lang->asb_last_poster_avatar_title,
                "description" => $lang->asb_last_poster_avatar_desc,
                "optionscode" => "yesno",
                "value" => '0'
            ),
            "avatar_width" => array(
                "sid" => "NULL",
                "name" => "avatar_width",
                "title" => $lang->asb_avatar_width_title,
                "description" => $lang->asb_avatar_width_desc,
                "optionscode" => "text",
                "value" => '30'
            ),
            "xmlhttp_on" => array(
                "sid" => "NULL",
                "name" => "xmlhttp_on",
                "title" => $lang->asb_xmlhttp_on_title,
                "description" => $lang->asb_xmlhttp_on_description,
                "optionscode" => "text",
                "value" => '0'
            )
        ),
        "templates" => array(
            array(
                "title" => "asb_latest_threads_thread",
                "template" => <<<EOF
                <tr>
                    <td class="{\$altbg}">
                        {\$gotounread}<a href="{\$mybb->settings[\'bburl\']}/{\$thread[\'threadlink\']}" title="{\$thread[\'subject\']}"><strong>{\$thread[\'subject\']}</strong></a>
                        <span class="smalltext"><br />
                            {\$last_poster}<br />
                            {\$lastpostdate} {\$lastposttime}<br />
                            <strong>» </strong>{\$lang->asb_latest_threads_replies} {\$thread[\'replies\']}<br />
                            <strong>» </strong>{\$lang->asb_latest_threads_views} {\$thread[\'views\']}
                        </span>
                    </td>
                </tr>
EOF
            ),
            array(
                "title" => "asb_latest_threads_gotounread",
                "template" => <<<EOF
<a href="{\$thread[\'newpostlink\']}"><img src="{\$theme[\'imgdir\']}/jump.gif" alt="{\$lang->asb_gotounread}" title="{\$lang->asb_gotounread}" /></a>
EOF
            ),
            array(
                "title" => "asb_latest_threads_last_poster_name",
                "template" => <<<EOF
<a href="{\$thread[\'lastpostlink\']}" title="{\$lang->asb_latest_threads_lastpost}">{\$lang->asb_latest_threads_lastpost}:</a> {\$lastposterlink}
EOF
            ),
            array(
                "title" => "asb_latest_threads_last_poster_avatar",
                "template" => <<<EOF
{\$lastposterlink}<br /><a href="{\$thread[\'lastpostlink\']}" title="{\$lang->asb_latest_threads_lastpost}">{\$lang->asb_latest_threads_lastpost}</a>
EOF
            )
        )
    );
}
/*
 * asb_latest_threads_build_template()
 *
 * handles display of children of this addon at page load
 *
 * @param - $args - (array) the specific information from the child box
 * @return: (bool) true on success, false on fail/no content
 */
function asb_latest_threads_build_template($args)
{
    extract($args);
    global $$template_var, $lang;
    if(!$lang->asb_addon)
    {
        $lang->load('asb_addon');
    }
    // get the threads (or at least attempt to)
    $all_threads = latest_threads_get_threadlist($settings, $width);
    if($all_threads)
    {
        // if there are threads, show them
        $$template_var = $all_threads;
        return true;
    }
    else
    {
        // if not, show nothing
        $$template_var = <<<EOF
<tr><td class="trow1">{$lang->asb_latest_threads_no_threads}</td></tr>
EOF;
        return false;
    }
}
/*
 * asb_latest_threads_xmlhttp()
 *
 * handles display of children of this addon via AJAX
 *
 * @param - $args - (array) the specific information from the child box
 * @return: n/a
 */
function asb_latest_threads_xmlhttp($args)
{
    extract($args);
    global $db;
    // do a quick check to make sure we don't waste execution
    $query = $db->simple_select('posts', '*', "dateline > {$dateline}");
    if($db->num_rows($query) > 0)
    {
        $all_threads = latest_threads_get_threadlist($settings, $width);
        if($all_threads)
        {
            return $all_threads;
        }
    }
    return 'nochange';
}
/*
 * latest_threads_get_threadlist()
 *
 * get the latest forum discussions
 *
 * @param - $settings (array) individual side box settings passed to the module
 * @param - $width - (int) the width of the column in which the child is positioned
 * @return: (mixed) a (string) containing the HTML side box markup or
 * (bool) false on fail/no content
 */
function latest_threads_get_threadlist($settings, $width)
{
    global $db, $mybb, $templates, $lang, $cache, $gotounread, $theme;
    if(!$lang->asb_addon)
    {
        $lang->load('asb_addon');
    }
    if($mybb->user['uid'] == 0)
    {
        $query = $db->query("
            SELECT
                fid
            FROM " .
                TABLE_PREFIX . "forums
            WHERE
                active != 0
            ORDER BY
                pid, disporder
        ");
        $forumsread = my_unserialize($mybb->cookies['mybb']['forumread']);
    }
    else
    {
        $query = $db->query("
            SELECT
                f.fid, 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)
        {
            if($forumsread[$forum['fid']])
            {
                $forum['lastread'] = $forumsread[$forum['fid']];
            }
        }
        $readforums[$forum['fid']] = $forum['lastread'];
    }
    // Build a post parser
    require_once MYBB_ROOT."inc/class_parser.php";
    $parser = new postParser;
    // get forums user cannot view
    $unviewable = get_unviewable_forums(true);
    if($unviewable)
    {
        $unviewwhere = " AND t.fid NOT IN ({$unviewable})";
    }
    // build the exclude conditions
    $show['fids'] = asb_build_id_list($settings['forum_show_list']['value'], 't.fid');
    $show['tids'] = asb_build_id_list($settings['thread_show_list']['value'], 't.tid');
    $hide['fids'] = asb_build_id_list($settings['forum_hide_list']['value'], 't.fid');
    $hide['tids'] = asb_build_id_list($settings['thread_hide_list']['value'], 't.tid');
    $where['show'] = asb_build_SQL_where($show, ' OR ');
    $where['hide'] = asb_build_SQL_where($hide, ' OR ', ' NOT ');
    $query_where = $unviewwhere . asb_build_SQL_where($where, ' AND ', ' AND ');
    $altbg = alt_trow();
    $maxtitlelen = 48;
    $threadlist = '';
    // query for the latest forum discussions
    $query = $db->query("
        SELECT
            t.*,
            u.username, u.avatar, u.usergroup, u.displaygroup
        FROM " .
            TABLE_PREFIX . "threads t
        LEFT JOIN " .
            TABLE_PREFIX . "users u ON (u.uid=t.lastposteruid)
        WHERE
            t.visible='1' AND t.closed NOT LIKE 'moved|%'{$query_where}
        ORDER BY
            t.lastpost DESC
        LIMIT
            0, " . (int) $settings['max_threads']['value']
    );
    if($db->num_rows($query) == 0)
    {
        // no content
        return false;
    }
    $thread_cache = array();
    while($thread = $db->fetch_array($query))
    {
        $thread_cache[$thread['tid']] = $thread;
    }
    $thread_ids = implode(",", array_keys($thread_cache));
    // Fetch the read threads.
    if($mybb->user['uid'] && $mybb->settings['threadreadcut'] > 0)
    {
        $query = $db->simple_select("threadsread", "tid,dateline", "uid='".$mybb->user['uid']."' AND tid IN(" . $thread_ids . ")");
        while($readthread = $db->fetch_array($query))
        {
            $thread_cache[$readthread['tid']]['lastread'] = $readthread['dateline'];
        }
    }
    foreach($thread_cache as $thread)
    {
        $forumpermissions[$thread['fid']] = forum_permissions($thread['fid']);
        // make sure we can view this thread
        if($forumpermissions[$thread['fid']]['canview'] == 0 || $forumpermissions[$thread['fid']]['canviewthreads'] == 0 || $forumpermissions[$thread['fid']]['canonlyviewownthreads'] == 1 && $thread['uid'] != $mybb->user['uid'])
        {
            continue;
        }
        $lastpostdate = my_date($mybb->settings['dateformat'], $thread['lastpost']);
        //Die ("lpd = ".$lastpostdate);
        $lastposttime = my_date($mybb->settings['timeformat'], $thread['lastpost']);
        // don't link to guest's profiles (they have no profile).
        if($thread['lastposteruid'] == 0)
        {
            $lastposterlink = $thread['lastposter'];
        }
        else
        {
            if($settings['last_poster_avatar']['value'])
            {
                if(strlen(trim($thread['avatar'])) == 0)
                {
                    $thread['avatar'] = "{$theme['imgdir']}/default_avatar.gif";
                }
                $avatar_width = (int) min($width / 2, max($width / 8, $settings['avatar_width']['value']));
                $last_poster_name1 = format_name($thread['username'], $thread['usergroup'], $thread['displaygroup']);
                $last_poster_name = <<<EOF
<img src="{$thread['avatar']}" alt="{$thread['last_post']}" title="{$thread['lastposter']}'s profile" style="width: {$avatar_width}px;"/> {$last_poster_name1}
EOF;
                //$lastposterlink = format_name($thread['lastposter'], $thread['usergroup'], $thread['displaygroup']);
                $lp_template = 'asb_latest_threads_last_poster_avatar';
            }
            else
            {
                $last_poster_name = format_name($thread['lastposter'], $thread['usergroup'], $thread['displaygroup']);
                $lp_template = 'asb_latest_threads_last_poster_name';
            }
            $lastposterlink = build_profile_link($last_poster_name, $thread['lastposteruid']);
        }
        if(my_strlen($thread['subject']) > $maxtitlelen)
        {
            $thread['subject'] = my_substr($thread['subject'], 0, $maxtitlelen) . "...";
        }
        $thread['subject'] = htmlspecialchars_uni($parser->parse_badwords($thread['subject']));
        $thread['threadlink'] = get_thread_link($thread['tid']);
        $thread['lastpostlink'] = get_thread_link($thread['tid'], 0, "lastpost");
        eval("\$last_poster = \"" . $templates->get($lp_template) . "\";");
        $gotounread = '';
        $last_read = 0;
        if($mybb->settings['threadreadcut'] > 0 && $mybb->user['uid'])
        {
            $forum_read = $readforums[$thread['fid']];
            $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 = $forumsread[$thread['fid']];
        }
        if($mybb->settings['threadreadcut'] > 0 && $mybb->user['uid'] && $thread['lastpost'] > $forum_read)
        {
            if($thread['lastread'])
            {
                $last_read = $thread['lastread'];
            }
            else
            {
                $last_read = $read_cutoff;
            }
        }
        else
        {
            $last_read = my_get_array_cookie("threadread", $thread['tid']);
        }
        if($forum_read > $last_read)
        {
            $last_read = $forum_read;
        }
        if($thread['lastpost'] > $last_read && $last_read)
        {
            $thread['newpostlink'] = get_thread_link($thread['tid'], 0, "newpost");
            eval("\$gotounread = \"" . $templates->get("asb_latest_threads_gotounread") . "\";");
            $unreadpost = 1;
        }
        eval("\$threadlist .= \"".$templates->get("asb_latest_threads_thread")."\";");
        $altbg = alt_trow();
    }
    if($threadlist)
    {
        return $threadlist;
    }
    // no content
    return false;
}
?>