View Single Post
  #3  
Old 09-15-2008, 04:06 AM
biome.pat biome.pat is offline
 
Join Date: Aug 2008
Location: Toronto, ON, Canada
Posts: 43
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Oh dear. And this is where my amateur-ness shines through. I don't know PHP aside from the chunks I try to edit, so the grand structure is above me. Excuse me if my terminology is a little wonky, but how would I query info from a different table? In the user moderation section, all the info is queried from the "user" table, but the custom profile fields are in the "userfield" table. Is there an easy way to organize that so that I could get the userfield info into the $users array that all the other info is dumped in?

Drats. I don't make sense, do I?

Well thanks regardless Lynne!

--------------- Added [DATE]1221460988[/DATE] at [TIME]1221460988[/TIME] ---------------

Alright, so I managed to learn a little PHP, and the parts I changed around were the query_read and $cell = array() bits... I'd love to hear your input as to whether this looks OK. Barring any unforeseen database explosions, I look forward to hearing from you

PHP Code:
// ###################### Start moderate + coppa #######################
if ($_REQUEST['do'] == 'moderate')
{

    $users = $db->query_read("
        SELECT
            " . TABLE_PREFIX . "user.userid,
            " . TABLE_PREFIX . "user.username,
            " . TABLE_PREFIX . "user.email,
            " . TABLE_PREFIX . "user.ipaddress,
            " . TABLE_PREFIX . "userfield.field6,
            " . TABLE_PREFIX . "userfield.field7,
            " . TABLE_PREFIX . "userfield.field8
        FROM
            " . TABLE_PREFIX . "user,
            " . TABLE_PREFIX . "userfield
        WHERE usergroupid = 4
            AND " . TABLE_PREFIX . "user.userid = " . TABLE_PREFIX . "userfield.userid
        ORDER BY username
    ");
    if ($db->num_rows($users) == 0)
    {
        print_stop_message('no_matches_found');
    }
    else
    {
        ?>
        <script type="text/javascript">
        function js_check_radio(value)
        {
            for (var i = 0; i < document.cpform.elements.length; i++)
            {
                var e = document.cpform.elements[i];
                if (e.type == 'radio' && e.name.substring(0, 8) == 'validate')
                {
                    if (e.value == value)
                    {
                        e.checked = true;
                    }
                    else
                    {
                        e.checked = false;
                    }
                }
            }
        }
        </script>
        <?php
        print_form_header
('user''domoderate');
        
print_table_header($vbphrase['users_awaiting_moderation'], 6);
        
print_cells_row(array(
            
$vbphrase['username'],
            
"First",
            
"Last",
            
$vbphrase['email'],
            
"UTORid",
            
"<input type=\"button\" class=\"button\" value=\"" $vbphrase['accept_all'] . "\" onclick=\"js_check_radio(1)\" />
            <input type=\"button\" class=\"button\" value=\"" 
$vbphrase['delete_all'] . "\" onclick=\"js_check_radio(-1)\" />
            <input type=\"button\" class=\"button\" value=\"" 
$vbphrase['ignore_all'] . "\" onclick=\"js_check_radio(0)\" />"
        
), 0'thead', -3);
        while (
$user $db->fetch_array($users))
        {
            
$cell = array();
            
$cell[] = "<a href=\"user.php?" $vbulletin->session->vars['sessionurl'] . "do=edit&amp;u=$user[userid]\" target=\"_user\"><b>$user[username]</b></a>";
            
$cell[] = "$user[field6]";
            
$cell[] = "$user[field7]";
            
$cell[] = "<a href=\"mailto:$user[email]\">$user[email]</a>";
            
$cell[] = "$user[field8]";
            
$cell[] = "
                <label for=\"v_
$user[userid]\"><input type=\"radio\" name=\"validate[$user[userid]]\" value=\"1\" id=\"v_$user[userid]\" tabindex=\"1\" />$vbphrase[accept]</label>
                <label for=\"d_
$user[userid]\"><input type=\"radio\" name=\"validate[$user[userid]]\" value=\"-1\" id=\"d_$user[userid]\" tabindex=\"1\" />$vbphrase[delete]</label>
                <label for=\"i_
$user[userid]\"><input type=\"radio\" name=\"validate[$user[userid]]\" value=\"0\" id=\"i_$user[userid]\" tabindex=\"1\" checked=\"checked\" />$vbphrase[ignore]</label>
            "
;
            
print_cells_row($cell0'', -4);
        }

        require_once(
DIR '/includes/functions_misc.php');
        
$template fetch_phrase('validated''emailbody''email_');

        
print_table_break();
        
print_table_header($vbphrase['email_options']);
        
print_yes_no_row($vbphrase['send_email_to_accepted_users'], 'send_validated'1);
        
print_yes_no_row($vbphrase['send_email_to_deleted_users'], 'send_deleted'1);
        
print_description_row($vbphrase['email_will_be_sent_in_user_specified_language']);

        
print_table_break();
        
print_submit_row($vbphrase['continue']);
    }
}
Reply With Quote
 
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01893 seconds
  • Memory Usage 1,845KB
  • 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_php
  • (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