View Single Post
  #1  
Old 01-11-2010, 04:51 AM
CypherSTL CypherSTL is offline
 
Join Date: Mar 2006
Location: St. Charles, MO
Posts: 306
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default Profile Tab -- Tab Data displaying on every "Tab"

I've looked at other mods which also add profile tabs in VB4, and from what I can tell my plugin is coded properly.

However, when I load a Profile, the block data is being displayed on every tab, and not only on the tab it's told to.

Code:
$blocklist['myawards'] = array( 
    'class' => 'MyAwards', 
    'title' => $vbphrase['awards'], 
    'hook_location' => 'profile_left_last', 
    'wrap' => false 
); 

class vB_ProfileBlock_MyAwards extends vB_ProfileBlock 
{ 
    var $template_name = 'memberinfo_block_myawards'; 

    function confirm_empty_wrap() 
    { 
        return false; 
    } 

    function confirm_display() 
    { 
        return ($this->block_data['myawards'] != ''); 
    } 

    function prepare_output($id = '', $options = array()) 
    { 
        global $show, $vbphrase, $stylevar, $vbcollapse, $bgclass, $vbulletin; 
         
        require_once(DIR . '/includes/class_bbcode.php'); 
        $bbcode_parser =& new vB_BbCodeParser($this->registry, fetch_tag_list()); 

         
        $result = $this->registry->db->query_read(' 
            SELECT 
                * 
            FROM 
            ' . TABLE_PREFIX . 'award_user AS award_user 
                LEFT JOIN ' . TABLE_PREFIX . 'award AS award USING (award_id) 
            WHERE  
                award_user.userid = ' . $this->profile->userinfo['userid'] . ' 
                AND award.award_active = "1" 
            ORDER BY 
               '.$vbulletin->options['aw_awardorder'].' 
        '); 
         
                if (($vbulletin->options['aw_points']) AND ($this->profile->userinfo['userid'])) 
                { 
                    $userpoints = $this->registry->db->query_read(' 
                        SELECT a.*, au.*, SUM(award_pointvalue) AS TotalPoints 
                        FROM ' . TABLE_PREFIX . 'award a, ' . TABLE_PREFIX . 'award_user au 
                        WHERE (au.userid = '.$this->profile->userinfo['userid'].') AND (a.award_id=au.award_id) AND (a.award_active = "1") 
                    '); 
                 
                    while ($array = $this->registry->db->fetch_array($userpoints)) 
                        { 
                        $this->block_data['total_points'] = $array['TotalPoints']; 
                        }   
                } 
         
        $num = $this->block_data['num'] = $this->registry->db->num_rows($result); 
         
        $this->block_data['myawards'] = ''; 
         
        if ($num > 0) 
        { 
            // Display Awards 
            while ($award = $this->registry->db->fetch_array($result)) 
            { 
                exec_switch_bg(); 
                 
                $award['award_desc'] = $bbcode_parser->parse($award['award_desc']); 
                $award['issue_reason'] = $bbcode_parser->parse($award['issue_reason']); 
                 
                $award_issue_date = vbdate($this->registry->options['dateformat'], $award['issue_time'], true); 
                $award_issue_time = vbdate($this->registry->options['timeformat'], $award['issue_time']); 
                 
                //- VB3 -// eval('$this->block_data[\'myawards\'] .= "' . fetch_template('awards_userawards_bit') . '";'); 
                //- BEGIN VB4 -// 
                $templater = vB_Template::create('awards_userawards_bit'); 
                    $templater->register('award', $award); 
                    $templater->register('award_issue_date', $award_issue_date); 
                    $templater->register('award_issue_time', $award_issue_time); 
                $uawardbits .= $templater->render(); 
                //- END VB4 -// 
            } 
        } 
$this->block_data['myawards'] = $uawardbits; 
    } 
}  

Any ideas?
Reply With Quote
 
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01374 seconds
  • Memory Usage 1,824KB
  • Queries Executed 11 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD_SHOWPOST
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)bbcode_code
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_box
  • (1)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit_info
  • (1)postbit
  • (1)postbit_onlinestatus
  • (1)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • reputationlevel
  • showthread
Included Files:
  • ./showpost.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showpost_start
  • bbcode_fetch_tags
  • bbcode_create
  • postbit_factory
  • showpost_post
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • showpost_complete