<?php
/*
 * You may not change or alter any portion of this comment or credits
 * of supporting developers from this source code or any supporting source code
 * which is considered copyrighted (c) material of the original comment or credit authors.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 */
/**
 * @copyright    XOOPS Project http://xoops.org/
 * @license      GNU GPL 2 or later (http://www.gnu.org/licenses/gpl-2.0.html)
 * @package
 * @since
 * @author       XOOPS Development Team, Kazumi Ono (AKA onokazu)
 */
/* @var XoopsUser $xoopsUser */
/* @var XoopsModule $xoopsModule */
// Check users rights
if (!is_object($xoopsUser) || !is_object($xoopsModule) || !$xoopsUser->isAdmin($xoopsModule->mid())) {
    exit(_NOPERM);
}
include_once XOOPS_ROOT_PATH . '/modules/system/admin/users/users.php';
// Get Action type
$op = system_CleanVars($_REQUEST, 'op', 'default', 'string');
/* @var XoopsMemberHandler $member_handler */
$member_handler = xoops_getHandler('member', 'system');
// Define main template
$GLOBALS['xoopsOption']['template_main'] = 'system_users.tpl';
// Call Header
xoops_cp_header();
$myts = MyTextSanitizer::getInstance();
// Define Stylesheet
$xoTheme->addStylesheet(XOOPS_URL . '/modules/system/css/admin.css');
$xoTheme->addStylesheet(XOOPS_URL . '/modules/system/css/ui/' . xoops_getModuleOption('jquery_theme', 'system') . '/ui.all.css');
// Define scripts
$xoTheme->addScript('modules/system/js/admin.js');
// Define Breadcrumb and tips
$xoBreadCrumb->addLink(_AM_SYSTEM_USERS_NAV_MAIN, system_adminVersion('users', 'adminpath'));
$uid = system_CleanVars($_REQUEST, 'uid', 0);
switch ($op) {
    // Edit user
    case 'users_edit':
        // Assign Breadcrumb menu
        $xoBreadCrumb->addHelp(system_adminVersion('users', 'help') . '#edit');
        $xoBreadCrumb->addLink(_AM_SYSTEM_USERS_NAV_EDIT_USER);
        $xoBreadCrumb->render();
        form_user(false, $uid);
        break;
    // Add user
    case 'users_add':
        // Assign Breadcrumb menu
        $xoBreadCrumb->addHelp(system_adminVersion('users', 'help') . '#add');
        $xoBreadCrumb->addLink(_AM_SYSTEM_USERS_NAV_ADD_USER);
        $xoBreadCrumb->render();
        form_user(true);
        break;
    // Delete user
    case 'users_delete':
        $xoBreadCrumb->render();
        $user = $member_handler->getUser($uid);
        if (isset($_REQUEST['ok']) && $_REQUEST['ok'] == 1) {
            if (!$GLOBALS['xoopsSecurity']->check()) {
                redirect_header('admin.php?fct=users', 3, implode('<br>', $GLOBALS['xoopsSecurity']->getErrors()));
            }
            $groups = $user->getGroups();
            if (in_array(XOOPS_GROUP_ADMIN, $groups)) {
                xoops_error(sprintf(_AM_SYSTEM_USERS_NO_ADMINSUPP, $user->getVar('uname')));
            } elseif (!$member_handler->deleteUser($user)) {
                xoops_error(sprintf(_AM_SYSTEM_USERS_NO_SUPP, $user->getVar('uname')));
            } else {
                /* @var XoopsOnlineHandler $online_handler */
                $online_handler = xoops_getHandler('online');
                $online_handler->destroy($uid);
                // RMV-NOTIFY
                xoops_notification_deletebyuser($uid);
                redirect_header('admin.php?fct=users', 1, _AM_SYSTEM_DBUPDATED);
            }
        } else {
            //Assign Breadcrumb menu
            $xoBreadCrumb->addHelp(system_adminVersion('users', 'help') . '#delete');
            $xoBreadCrumb->addLink(_AM_SYSTEM_USERS_NAV_DELETE_USER);
            $xoBreadCrumb->render();
            xoops_confirm(array(
                              'ok'  => 1,
                              'uid' => $uid,
                              'op'  => 'users_delete'), $_SERVER['REQUEST_URI'], sprintf(_AM_SYSTEM_USERS_FORM_SURE_DEL, $user->getVar('uname')));
        }
        break;
    // Delete users
    case 'action_group':
        if (!$GLOBALS['xoopsSecurity']->check()) {
            redirect_header('admin.php?fct=users', 3, implode('<br>', $GLOBALS['xoopsSecurity']->getErrors()));
        }
        if (@isset($_REQUEST['memberslist_id']) || @$_REQUEST['memberslist_id'] !== '') {
            $xoBreadCrumb->render();
            $error = '';
            foreach ($_REQUEST['memberslist_id'] as $del) {
                $del    = (int)$del;
                $user   = $member_handler->getUser($del);
                $groups = $user->getGroups();
                if (in_array(XOOPS_GROUP_ADMIN, $groups)) {
                    $error .= sprintf(_AM_SYSTEM_USERS_NO_ADMINSUPP, $user->getVar('uname'));
                } elseif (!$member_handler->deleteUser($user)) {
                    $error .= sprintf(_AM_SYSTEM_USERS_NO_SUPP, $user->getVar('uname'));
                } else {
                    /* @var XoopsOnlineHandler $online_handler */
                    $online_handler = xoops_getHandler('online');
                    $online_handler->destroy($del);
                    // RMV-NOTIFY
                    xoops_notification_deletebyuser($del);
                }
            }
            if ($error !== '') {
                redirect_header('admin.php?fct=users', 3, sprintf(_AM_SYSTEM_USERS_ERROR, $error));
            } else {
                redirect_header('admin.php?fct=users', 1, _AM_SYSTEM_DBUPDATED);
            }
        }
        break;
    // Save user
    case 'users_save':
        global $xoopsConfig, $xoopsModule, $xoopsUser;
        if (isset($_REQUEST['uid'])) {
            //Update user
            if (!$GLOBALS['xoopsSecurity']->check()) {
                redirect_header('admin.php?fct=users', 3, implode('<br>', $GLOBALS['xoopsSecurity']->getErrors()));
            }
            // RMV-NOTIFY
            $user_avatar = $theme = null;
            if (!isset($_REQUEST['attachsig'])) {
                $attachsig = null;
            }
            if (!isset($_REQUEST['user_viewemail'])) {
                $user_viewemail = null;
            }
            $edituser = $member_handler->getUser($uid);
            if ($edituser->getVar('uname', 'n') != $_REQUEST['username'] && $member_handler->getUserCount(new Criteria('uname', $myts->addSlashes($_REQUEST['username']))) > 0) {
                xoops_cp_header();
                xoops_error(sprintf(_AM_SYSTEM_USERS_PSEUDO_ERROR, htmlspecialchars($_REQUEST['username'])));
                xoops_cp_footer();
            } elseif ($edituser->getVar('email', 'n') != $_REQUEST['email'] && $member_handler->getUserCount(new Criteria('email', $myts->addSlashes($_REQUEST['email']))) > 0) {
                xoops_cp_header();
                xoops_error(sprintf(_AM_SYSTEM_USERS_MAIL_ERROR, htmlspecialchars($_REQUEST['email'])));
                xoops_cp_footer();
            } else {
                $edituser->setVar('name', $_REQUEST['name']);
                $edituser->setVar('uname', $_REQUEST['username']);
                $edituser->setVar('email', $_REQUEST['email']);
                $url = isset($_REQUEST['url']) ? formatURL($_REQUEST['url']) : '';
                $edituser->setVar('url', $url);
                $edituser->setVar('user_icq', $_REQUEST['user_icq']);
                $edituser->setVar('user_from', $_REQUEST['user_from']);
                $edituser->setVar('user_sig', $_REQUEST['user_sig']);
                $user_viewemail = (isset($_REQUEST['user_viewemail']) && $_REQUEST['user_viewemail'] == 1) ? 1 : 0;
                $edituser->setVar('user_viewemail', $user_viewemail);
                $edituser->setVar('user_aim', $_REQUEST['user_aim']);
                $edituser->setVar('user_yim', $_REQUEST['user_yim']);
                $edituser->setVar('user_msnm', $_REQUEST['user_msnm']);
                $attachsig = (isset($_REQUEST['attachsig']) && $_REQUEST['attachsig'] == 1) ? 1 : 0;
                $edituser->setVar('attachsig', $attachsig);
                $edituser->setVar('timezone_offset', $_REQUEST['timezone_offset']);
                $edituser->setVar('uorder', $_REQUEST['uorder']);
                $edituser->setVar('umode', $_REQUEST['umode']);
                // RMV-NOTIFY
                $edituser->setVar('notify_method', $_REQUEST['notify_method']);
                $edituser->setVar('notify_mode', $_REQUEST['notify_mode']);
                $edituser->setVar('bio', $_REQUEST['bio']);
                $edituser->setVar('rank', $_REQUEST['rank']);
                $edituser->setVar('user_occ', $_REQUEST['user_occ']);
                $edituser->setVar('user_intrest', $_REQUEST['user_intrest']);
                $edituser->setVar('user_mailok', $_REQUEST['user_mailok']);
                if ($_REQUEST['pass2'] !== '') {
                    if ($_REQUEST['password'] != $_REQUEST['pass2']) {
                        xoops_cp_header();
                        echo '
                        <strong>' . _AM_SYSTEM_USERS_STNPDNM . '</strong>';
                        xoops_cp_footer();
                        exit();
                    }
                    $edituser->setVar('pass', password_hash($_REQUEST['password'], PASSWORD_DEFAULT));
                }
                if (!$member_handler->insertUser($edituser)) {
                    xoops_cp_header();
                    echo $edituser->getHtmlErrors();
                    xoops_cp_footer();
                } else {
                    if ($_REQUEST['groups'] != array()) {
                        global $xoopsUser;
                        $oldgroups = $edituser->getGroups();
                        //If the edited user is the current user and the current user WAS in the webmaster's group and is NOT in the new groups array
                        if ($edituser->getVar('uid') == $xoopsUser->getVar('uid') && in_array(XOOPS_GROUP_ADMIN, $oldgroups) && !in_array(XOOPS_GROUP_ADMIN, $_REQUEST['groups'])) {
                            //Add the webmaster's group to the groups array to prevent accidentally removing oneself from the webmaster's group
                            $_REQUEST['groups'][] = XOOPS_GROUP_ADMIN;
                        }
                        /* @var XoopsMemberHandler $member_handler */
                        $member_handler = xoops_getHandler('member');
                        foreach ($oldgroups as $groupid) {
                            $member_handler->removeUsersFromGroup($groupid, array($edituser->getVar('uid')));
                        }
                        foreach ($_REQUEST['groups'] as $groupid) {
                            $member_handler->addUserToGroup($groupid, $edituser->getVar('uid'));
                        }
                    }
                    redirect_header('admin.php?fct=users', 1, _AM_SYSTEM_DBUPDATED);
                }
            }
            exit();
        } else {
            //Add user
            if (!$GLOBALS['xoopsSecurity']->check()) {
                redirect_header('admin.php?fct=users', 3, implode('<br>', $GLOBALS['xoopsSecurity']->getErrors()));
            }
            if (!$_REQUEST['username'] || !$_REQUEST['email'] || !$_REQUEST['password']) {
                $adduser_errormsg = _AM_SYSTEM_USERS_YMCACF;
            } else {
                /* @var XoopsMemberHandler $member_handler */
                $member_handler = xoops_getHandler('member');
                // make sure the username doesnt exist yet
                if ($member_handler->getUserCount(new Criteria('uname', $myts->addSlashes($_REQUEST['username']))) > 0) {
                    $adduser_errormsg = 'User name ' . htmlspecialchars($_REQUEST['username']) . ' already exists';
                } else {
                    $newuser = $member_handler->createUser();
                    if (isset($user_viewemail)) {
                        $newuser->setVar('user_viewemail', $_REQUEST['user_viewemail']);
                    }
                    if (isset($attachsig)) {
                        $newuser->setVar('attachsig', $_REQUEST['attachsig']);
                    }
                    $newuser->setVar('name', $_REQUEST['name']);
                    $newuser->setVar('uname', $_REQUEST['username']);
                    $newuser->setVar('email', $_REQUEST['email']);
                    $newuser->setVar('url', formatURL($_REQUEST['url']));
                    $newuser->setVar('user_avatar', 'avatars/blank.gif');
                    $newuser->setVar('user_regdate', time());
                    $newuser->setVar('user_icq', $_REQUEST['user_icq']);
                    $newuser->setVar('user_from', $_REQUEST['user_from']);
                    $newuser->setVar('user_sig', $_REQUEST['user_sig']);
                    $newuser->setVar('user_aim', $_REQUEST['user_aim']);
                    $newuser->setVar('user_yim', $_REQUEST['user_yim']);
                    $newuser->setVar('user_msnm', $_REQUEST['user_msnm']);
                    if ($_REQUEST['pass2'] !== '') {
                        if ($_REQUEST['password'] != $_REQUEST['pass2']) {
                            xoops_cp_header();
                            echo '<strong>' . _AM_SYSTEM_USERS_STNPDNM . '</strong>';
                            xoops_cp_footer();
                            exit();
                        }
                        $newuser->setVar('pass', password_hash($_REQUEST['password'], PASSWORD_DEFAULT));
                    }
                    $newuser->setVar('timezone_offset', $_REQUEST['timezone_offset']);
                    $newuser->setVar('uorder', $_REQUEST['uorder']);
                    $newuser->setVar('umode', $_REQUEST['umode']);
                    // RMV-NOTIFY
                    $newuser->setVar('notify_method', $_REQUEST['notify_method']);
                    $newuser->setVar('notify_mode', $_REQUEST['notify_mode']);
                    $newuser->setVar('bio', $_REQUEST['bio']);
                    $newuser->setVar('rank', $_REQUEST['rank']);
                    $newuser->setVar('level', 1);
                    $newuser->setVar('user_occ', $_REQUEST['user_occ']);
                    $newuser->setVar('user_intrest', $_REQUEST['user_intrest']);
                    $newuser->setVar('user_mailok', $_REQUEST['user_mailok']);
                    if (!$member_handler->insertUser($newuser)) {
                        $adduser_errormsg = _AM_SYSTEM_USERS_CNRNU;
                    } else {
                        $groups_failed = array();
                        foreach ($_REQUEST['groups'] as $group) {
                            $group = (int)$group;
                            if (!$member_handler->addUserToGroup($group, $newuser->getVar('uid'))) {
                                $groups_failed[] = $group;
                            }
                        }
                        if (!empty($groups_failed)) {
                            $group_names      = $member_handler->getGroupList(new Criteria('groupid', '(' . implode(', ', $groups_failed) . ')', 'IN'));
                            $adduser_errormsg = sprintf(_AM_SYSTEM_USERS_CNRNU2, implode(', ', $group_names));
                        } else {
                            xoops_load('XoopsUserUtility');
                            XoopsUserUtility::sendWelcome($newuser);
                            redirect_header('admin.php?fct=users', 1, _AM_SYSTEM_DBUPDATED);
                        }
                    }
                }
            }
            xoops_error($adduser_errormsg);
        }
        break;
    // Activ member
    case 'users_active':
        if (isset($_REQUEST['uid'])) {
            $obj = $member_handler->getUser($uid);
            //echo $_REQUEST["uid"];
            //print_r($obj);
        }
        $obj->setVar('level', 1);
        if ($member_handler->insertUser($obj, true)) {
            redirect_header('admin.php?fct=users', 1, _AM_SYSTEM_DBUPDATED);
        }
        echo $obj->getHtmlErrors();
        break;
    // Synchronize
    case 'users_synchronize':
        if (isset($_REQUEST['status']) && $_REQUEST['status'] == 1) {
            synchronize($$uid, 'user');
        } elseif (isset($_REQUEST['status']) && $_REQUEST['status'] == 2) {
            synchronize('', 'all users');
        }
        redirect_header('admin.php?fct=users', 1, _AM_SYSTEM_DBUPDATED);
        break;
    default:
        // Search and Display
        // Define scripts
        $xoTheme->addScript('browse.php?Frameworks/jquery/jquery.js');
        $xoTheme->addScript('browse.php?Frameworks/jquery/plugins/jquery.ui.js');
        //table sorting does not work with select boxes
        //$xoTheme->addScript('browse.php?Frameworks/jquery/plugins/jquery.tablesorter.js');
        $xoTheme->addScript('modules/system/js/admin.js');
        //Recherche approfondie
        if (isset($_REQUEST['complet_search'])) {
            // Assign Breadcrumb menu
            $xoBreadCrumb->addLink(_AM_SYSTEM_USERS_NAV_ADVANCED_SEARCH);
            $xoBreadCrumb->addHelp(system_adminVersion('users', 'help'));
            $xoBreadCrumb->addTips(_AM_SYSTEM_USERS_NAV_TIPS);
            $xoBreadCrumb->render();
            $acttotal   = $member_handler->getUserCount(new Criteria('level', 0, '>'));
            $inacttotal = $member_handler->getUserCount(new Criteria('level', 0));
            //$group_select = new XoopsFormSelectGroup(_AM_SYSTEM_USERS_GROUPS, "selgroups", null, false, 1, false);
            $group_select = new XoopsFormSelect(_AM_SYSTEM_USERS_GROUPS, 'selgroups');
            /* @var XoopsGroupHandler $group_handler */
            $group_handler = xoops_getHandler('group');
            $group_arr     = $group_handler->getObjects();
            $group_select->addOption('', '--------------');
            foreach (array_keys($group_arr) as $i) {
                if ($group_arr[$i]->getVar('groupid') != XOOPS_GROUP_ANONYMOUS) {
                    $group_select->addOption('' . $group_arr[$i]->getVar('groupid') . '', '' . $group_arr[$i]->getVar('name') . '');
                }
            }
            $uname_text  = new XoopsFormText('', 'user_uname', 30, 60);
            $uname_match = new XoopsFormSelectMatchOption('', 'user_uname_match');
            $uname_tray  = new XoopsFormElementTray(_AM_SYSTEM_USERS_UNAME, ' ');
            $uname_tray->addElement($uname_match);
            $uname_tray->addElement($uname_text);
            $name_text  = new XoopsFormText('', 'user_name', 30, 60);
            $name_match = new XoopsFormSelectMatchOption('', 'user_name_match');
            $name_tray  = new XoopsFormElementTray(_AM_SYSTEM_USERS_REALNAME, ' ');
            $name_tray->addElement($name_match);
            $name_tray->addElement($name_text);
            $email_text  = new XoopsFormText('', 'user_email', 30, 60);
            $email_match = new XoopsFormSelectMatchOption('', 'user_email_match');
            $email_tray  = new XoopsFormElementTray(_AM_SYSTEM_USERS_EMAIL, ' ');
            $email_tray->addElement($email_match);
            $email_tray->addElement($email_text);
            $url_text  = new XoopsFormText(_AM_SYSTEM_USERS_URLC, 'user_url', 30, 100);
            $icq_text  = new XoopsFormText('', 'user_icq', 30, 100);
            $icq_match = new XoopsFormSelectMatchOption('', 'user_icq_match');
            $icq_tray  = new XoopsFormElementTray(_AM_SYSTEM_USERS_ICQ, ' ');
            $icq_tray->addElement($icq_match);
            $icq_tray->addElement($icq_text);
            $aim_text  = new XoopsFormText('', 'user_aim', 30, 100);
            $aim_match = new XoopsFormSelectMatchOption('', 'user_aim_match');
            $aim_tray  = new XoopsFormElementTray(_AM_SYSTEM_USERS_AIM, ' ');
            $aim_tray->addElement($aim_match);
            $aim_tray->addElement($aim_text);
            $yim_text  = new XoopsFormText('', 'user_yim', 30, 100);
            $yim_match = new XoopsFormSelectMatchOption('', 'user_yim_match');
            $yim_tray  = new XoopsFormElementTray(_AM_SYSTEM_USERS_YIM, ' ');
            $yim_tray->addElement($yim_match);
            $yim_tray->addElement($yim_text);
            $msnm_text  = new XoopsFormText('', 'user_msnm', 30, 100);
            $msnm_match = new XoopsFormSelectMatchOption('', 'user_msnm_match');
            $msnm_tray  = new XoopsFormElementTray(_AM_SYSTEM_USERS_MSNM, ' ');
            $msnm_tray->addElement($msnm_match);
            $msnm_tray->addElement($msnm_text);
            $location_text   = new XoopsFormText(_AM_SYSTEM_USERS_LOCATIONC, 'user_from', 30, 100);
            $occupation_text = new XoopsFormText(_AM_SYSTEM_USERS_OCCUPATIONC, 'user_occ', 30, 100);
            $interest_text   = new XoopsFormText(_AM_SYSTEM_USERS_INTERESTC, 'user_intrest', 30, 100);
            $lastlog_more = new XoopsFormText(_AM_SYSTEM_USERS_LASTLOGMORE, 'user_lastlog_more', 10, 5);
            $lastlog_less = new XoopsFormText(_AM_SYSTEM_USERS_LASTLOGLESS, 'user_lastlog_less', 10, 5);
            $reg_more     = new XoopsFormText(_AM_SYSTEM_USERS_REGMORE, 'user_reg_more', 10, 5);
            $reg_less     = new XoopsFormText(_AM_SYSTEM_USERS_REGLESS, 'user_reg_less', 10, 5);
            $posts_more   = new XoopsFormText(_AM_SYSTEM_USERS_POSTSMORE, 'user_posts_more', 10, 5);
            $posts_less   = new XoopsFormText(_AM_SYSTEM_USERS_POSTSLESS, 'user_posts_less', 10, 5);
            $mailok_radio = new XoopsFormRadio(_AM_SYSTEM_USERS_SHOWMAILOK, 'user_mailok', 'both');
            $mailok_radio->addOptionArray(array(
                                              'mailok' => _AM_SYSTEM_USERS_MAILOK,
                                              'mailng' => _AM_SYSTEM_USERS_MAILNG,
                                              'both' => _AM_SYSTEM_USERS_BOTH));
            $type_radio = new XoopsFormRadio(_AM_SYSTEM_USERS_SHOWTYPE, 'user_type', 'actv');
            $type_radio->addOptionArray(array(
                                            'actv' => _AM_SYSTEM_USERS_ACTIVE,
                                            'inactv' => _AM_SYSTEM_USERS_INACTIVE,
                                            'both' => _AM_SYSTEM_USERS_BOTH));
            $sort_select = new XoopsFormSelect(_AM_SYSTEM_USERS_SORT, 'user_sort');
            $sort_select->addOptionArray(array(
                                             'uname' => _AM_SYSTEM_USERS_UNAME,
                                             'email' => _AM_SYSTEM_USERS_EMAIL,
                                             'last_login' => _AM_SYSTEM_USERS_LASTLOGIN,
                                             'user_regdate' => _AM_SYSTEM_USERS_REGDATE,
                                             'posts' => _AM_SYSTEM_USERS_POSTS));
            $order_select = new XoopsFormSelect(_AM_SYSTEM_USERS_ORDER, 'user_order');
            $order_select->addOptionArray(array('ASC' => _AM_SYSTEM_USERS_ASC, 'DESC' => _AM_SYSTEM_USERS_DESC));
            $limit_text    = new XoopsFormText(_AM_SYSTEM_USERS_LIMIT, 'user_limit', 6, 2, 20);
            $submit_button = new XoopsFormButton('', 'user_submit', _SUBMIT, 'submit');
            $form = new XoopsThemeForm(_AM_SYSTEM_USERS_FINDUS, 'user_findform', 'admin.php?fct=users', 'post', true);
            $form->addElement($uname_tray);
            $form->addElement($name_tray);
            $form->addElement($email_tray);
            $form->addElement($group_select);
            $form->addElement($icq_tray);
            $form->addElement($aim_tray);
            $form->addElement($yim_tray);
            $form->addElement($msnm_tray);
            $form->addElement($url_text);
            $form->addElement($location_text);
            $form->addElement($occupation_text);
            $form->addElement($interest_text);
            $form->addElement($lastlog_more);
            $form->addElement($lastlog_less);
            $form->addElement($reg_more);
            $form->addElement($reg_less);
            $form->addElement($posts_more);
            $form->addElement($posts_less);
            $form->addElement($mailok_radio);
            $form->addElement($type_radio);
            $form->addElement($sort_select);
            $form->addElement($order_select);
            $form->addElement($fct_hidden);
            $form->addElement($limit_text);
            $form->addElement($op_hidden);
            // if this is to find users for a specific group
            if (!empty($_GET['group']) && (int)$_GET['group'] > 0) {
                $group_hidden = new XoopsFormHidden('group', (int)$_GET['group']);
                $form->addElement($group_hidden);
            }
            $form->addElement($submit_button);
            $form->display();
        } else {
            //Display data
            // Assign Breadcrumb menu
            $xoBreadCrumb->addHelp(system_adminVersion('users', 'help'));
            $xoBreadCrumb->addTips(_AM_SYSTEM_USERS_NAV_TIPS);
            $xoBreadCrumb->render();
            $requete_search  = '<br><br><strong>See search request: </strong><br><br>';
            $requete_pagenav = '';
            $criteria = new CriteriaCompo();
            if (!empty($_REQUEST['user_uname'])) {
                $match = (!empty($_REQUEST['user_uname_match'])) ? (int)$_REQUEST['user_uname_match'] : XOOPS_MATCH_START;
                switch ($match) {
                    case XOOPS_MATCH_START:
                        $criteria->add(new Criteria('uname', $myts->addSlashes(trim($_REQUEST['user_uname'])) . '%', 'LIKE'));
                        break;
                    case XOOPS_MATCH_END:
                        $criteria->add(new Criteria('uname', '%' . $myts->addSlashes(trim($_REQUEST['user_uname'])), 'LIKE'));
                        break;
                    case XOOPS_MATCH_EQUAL:
                        $criteria->add(new Criteria('uname', $myts->addSlashes(trim($_REQUEST['user_uname']))));
                        break;
                    case XOOPS_MATCH_CONTAIN:
                        $criteria->add(new Criteria('uname', '%' . $myts->addSlashes(trim($_REQUEST['user_uname'])) . '%', 'LIKE'));
                        break;
                }
                $requete_pagenav .= '&user_uname=' . htmlspecialchars($_REQUEST['user_uname']) . '&user_uname_match=' . htmlspecialchars($_REQUEST['user_uname_match']);
                $requete_search .= 'uname : ' . $_REQUEST['user_uname'] . ' et user_uname_match=' . $_REQUEST['user_uname_match'] . '<br>';
            }
            if (!empty($_REQUEST['user_name'])) {
                $match = (!empty($_REQUEST['user_name_match'])) ? (int)$_REQUEST['user_name_match'] : XOOPS_MATCH_START;
                switch ($match) {
                    case XOOPS_MATCH_START:
                        $criteria->add(new Criteria('name', $myts->addSlashes(trim($_REQUEST['user_name'])) . '%', 'LIKE'));
                        break;
                    case XOOPS_MATCH_END:
                        $criteria->add(new Criteria('name', '%' . $myts->addSlashes(trim($_REQUEST['user_name'])), 'LIKE'));
                        break;
                    case XOOPS_MATCH_EQUAL:
                        $criteria->add(new Criteria('name', $myts->addSlashes(trim($_REQUEST['user_name']))));
                        break;
                    case XOOPS_MATCH_CONTAIN:
                        $criteria->add(new Criteria('name', '%' . $myts->addSlashes(trim($_POST['user_name'])) . '%', 'LIKE'));
                        break;
                }
                $requete_pagenav .= '&user_name=' . htmlspecialchars($_REQUEST['user_name']) . '&user_name_match=' . htmlspecialchars($_REQUEST['user_name_match']);
                $requete_search .= 'name : ' . $_REQUEST['user_name'] . ' et user_name_match=' . $_REQUEST['user_name_match'] . '<br>';
            }
            if (!empty($_REQUEST['user_email'])) {
                $match = (!empty($_REQUEST['user_email_match'])) ? (int)$_REQUEST['user_email_match'] : XOOPS_MATCH_START;
                switch ($match) {
                    case XOOPS_MATCH_START:
                        $criteria->add(new Criteria('email', $myts->addSlashes(trim($_REQUEST['user_email'])) . '%', 'LIKE'));
                        break;
                    case XOOPS_MATCH_END:
                        $criteria->add(new Criteria('email', '%' . $myts->addSlashes(trim($_REQUEST['user_email'])), 'LIKE'));
                        break;
                    case XOOPS_MATCH_EQUAL:
                        $criteria->add(new Criteria('email', $myts->addSlashes(trim($_REQUEST['user_email']))));
                        break;
                    case XOOPS_MATCH_CONTAIN:
                        $criteria->add(new Criteria('email', '%' . $myts->addSlashes(trim($_REQUEST['user_email'])) . '%', 'LIKE'));
                        break;
                }
                $requete_pagenav .= '&user_email=' . htmlspecialchars($_REQUEST['user_email']) . '&user_email_match=' . htmlspecialchars($_REQUEST['user_email_match']);
                $requete_search .= 'email : ' . $_REQUEST['user_email'] . ' et user_email_match=' . $_REQUEST['user_email_match'] . '<br>';
            }
            if (!empty($_REQUEST['user_url'])) {
                $url = formatURL(trim($_REQUEST['user_url']));
                $criteria->add(new Criteria('url', '%' . $myts->addSlashes($url) . '%', 'LIKE'));
                $requete_pagenav .= '&user_url=' . htmlspecialchars($_REQUEST['user_url']);
                $requete_search .= 'url : ' . $_REQUEST['user_url'] . '<br>';
            }
            if (!empty($_REQUEST['user_icq'])) {
                $match = (!empty($_REQUEST['user_icq_match'])) ? (int)$_REQUEST['user_icq_match'] : XOOPS_MATCH_START;
                switch ($match) {
                    case XOOPS_MATCH_START:
                        $criteria->add(new Criteria('user_icq', $myts->addSlashes(trim($_REQUEST['user_icq'])) . '%', 'LIKE'));
                        break;
                    case XOOPS_MATCH_END:
                        $criteria->add(new Criteria('user_icq', '%' . $myts->addSlashes(trim($_REQUEST['user_icq'])), 'LIKE'));
                        break;
                    case XOOPS_MATCH_EQUAL:
                        $criteria->add(new Criteria('user_icq', $myts->addSlashes(trim($_REQUEST['user_icq']))));
                        break;
                    case XOOPS_MATCH_CONTAIN:
                        $criteria->add(new Criteria('user_icq', '%' . $myts->addSlashes(trim($_REQUEST['user_icq'])) . '%', 'LIKE'));
                        break;
                }
                $requete_pagenav .= '&user_icq=' . htmlspecialchars($_REQUEST['user_icq']) . '&user_icq_match=' . htmlspecialchars($_REQUEST['user_icq_match']);
                $requete_search .= 'icq : ' . $_REQUEST['user_icq'] . ' et user_icq_match=' . $_REQUEST['user_icq_match'] . '<br>';
            }
            if (!empty($_REQUEST['user_aim'])) {
                $match = (!empty($_REQUEST['user_aim_match'])) ? (int)$_REQUEST['user_aim_match'] : XOOPS_MATCH_START;
                switch ($match) {
                    case XOOPS_MATCH_START:
                        $criteria->add(new Criteria('user_aim', $myts->addSlashes(trim($_REQUEST['user_aim'])) . '%', 'LIKE'));
                        break;
                    case XOOPS_MATCH_END:
                        $criteria->add(new Criteria('user_aim', '%' . $myts->addSlashes(trim($_REQUEST['user_aim'])), 'LIKE'));
                        break;
                    case XOOPS_MATCH_EQUAL:
                        $criteria->add(new Criteria('user_aim', $myts->addSlashes(trim($_REQUEST['user_aim']))));
                        break;
                    case XOOPS_MATCH_CONTAIN:
                        $criteria->add(new Criteria('user_aim', '%' . $myts->addSlashes(trim($_REQUEST['user_aim'])) . '%', 'LIKE'));
                        break;
                }
                $requete_pagenav .= '&user_aim=' . htmlspecialchars($_REQUEST['user_aim']) . '&user_aim_match=' . htmlspecialchars($_REQUEST['user_aim_match']);
                $requete_search .= 'aim : ' . $_REQUEST['user_aim'] . ' et user_aim_match=' . $_REQUEST['user_aim_match'] . '<br>';
            }
            if (!empty($_REQUEST['user_yim'])) {
                $match = (!empty($_REQUEST['user_yim_match'])) ? (int)$_REQUEST['user_yim_match'] : XOOPS_MATCH_START;
                switch ($match) {
                    case XOOPS_MATCH_START:
                        $criteria->add(new Criteria('user_yim', $myts->addSlashes(trim($_REQUEST['user_yim'])) . '%', 'LIKE'));
                        break;
                    case XOOPS_MATCH_END:
                        $criteria->add(new Criteria('user_yim', '%' . $myts->addSlashes(trim($_REQUEST['user_yim'])), 'LIKE'));
                        break;
                    case XOOPS_MATCH_EQUAL:
                        $criteria->add(new Criteria('user_yim', $myts->addSlashes(trim($_REQUEST['user_yim']))));
                        break;
                    case XOOPS_MATCH_CONTAIN:
                        $criteria->add(new Criteria('user_yim', '%' . $myts->addSlashes(trim($_REQUEST['user_yim'])) . '%', 'LIKE'));
                        break;
                }
                $requete_pagenav .= '&user_yim=' . htmlspecialchars($_REQUEST['user_yim']) . '&user_yim_match=' . htmlspecialchars($_REQUEST['user_yim_match']);
                $requete_search .= 'yim : ' . $_REQUEST['user_yim'] . ' et user_yim_match=' . $_REQUEST['user_yim_match'] . '<br>';
            }
            if (!empty($_REQUEST['user_msnm'])) {
                $match = (!empty($_REQUEST['user_msnm_match'])) ? (int)$_REQUEST['user_msnm_match'] : XOOPS_MATCH_START;
                switch ($match) {
                    case XOOPS_MATCH_START:
                        $criteria->add(new Criteria('user_msnm', $myts->addSlashes(trim($_REQUEST['user_msnm'])) . '%', 'LIKE'));
                        break;
                    case XOOPS_MATCH_END:
                        $criteria->add(new Criteria('user_msnm', '%' . $myts->addSlashes(trim($_REQUEST['user_msnm'])), 'LIKE'));
                        break;
                    case XOOPS_MATCH_EQUAL:
                        $criteria->add(new Criteria('user_msnm', $myts->addSlashes(trim($_REQUEST['user_msnm']))));
                        break;
                    case XOOPS_MATCH_CONTAIN:
                        $criteria->add(new Criteria('user_msnm', '%' . $myts->addSlashes(trim($_REQUEST['user_msnm'])) . '%', 'LIKE'));
                        break;
                }
                $requete_pagenav .= '&user_msnm=' . htmlspecialchars($_REQUEST['user_msnm']) . '&user_msnm_match=' . htmlspecialchars($_REQUEST['user_msnm_match']);
                $requete_search .= 'msn : ' . $_REQUEST['user_msnm'] . ' et user_msnm_match=' . $_REQUEST['user_msnm_match'] . '<br>';
            }
            if (!empty($_REQUEST['user_from'])) {
                $criteria->add(new Criteria('user_from', '%' . $myts->addSlashes(trim($_REQUEST['user_from'])) . '%', 'LIKE'));
                $requete_pagenav .= '&user_from=' . htmlspecialchars($_REQUEST['user_from']);
                $requete_search .= 'from : ' . $_REQUEST['user_from'] . '<br>';
            }
            if (!empty($_REQUEST['user_intrest'])) {
                $criteria->add(new Criteria('user_intrest', '%' . $myts->addSlashes(trim($_REQUEST['user_intrest'])) . '%', 'LIKE'));
                $requete_pagenav .= '&user_intrest=' . htmlspecialchars($_REQUEST['user_intrest']);
                $requete_search .= 'interet : ' . $_REQUEST['user_intrest'] . '<br>';
            }
            if (!empty($_REQUEST['user_occ'])) {
                $criteria->add(new Criteria('user_occ', '%' . $myts->addSlashes(trim($_REQUEST['user_occ'])) . '%', 'LIKE'));
                $requete_pagenav .= '&user_occ=' . htmlspecialchars($_REQUEST['user_occ']);
                $requete_search .= 'location : ' . $_REQUEST['user_occ'] . '<br>';
            }
            if (!empty($_REQUEST['user_lastlog_more']) && is_numeric($_REQUEST['user_lastlog_more'])) {
                $f_user_lastlog_more = (int)trim($_REQUEST['user_lastlog_more']);
                $time                = time() - (60 * 60 * 24 * $f_user_lastlog_more);
                if ($time > 0) {
                    $criteria->add(new Criteria('last_login', $time, '<'));
                }
                $requete_pagenav .= '&user_lastlog_more=' . htmlspecialchars($_REQUEST['user_lastlog_more']);
                $requete_search .= 'derniere connexion apres : ' . $_REQUEST['user_lastlog_more'] . '<br>';
            }
            if (!empty($_REQUEST['user_lastlog_less']) && is_numeric($_REQUEST['user_lastlog_less'])) {
                $f_user_lastlog_less = (int)trim($_REQUEST['user_lastlog_less']);
                $time                = time() - (60 * 60 * 24 * $f_user_lastlog_less);
                if ($time > 0) {
                    $criteria->add(new Criteria('last_login', $time, '>'));
                }
                $requete_pagenav .= '&user_lastlog_less=' . htmlspecialchars($_REQUEST['user_lastlog_less']);
                $requete_search .= 'derniere connexion avant : ' . $_REQUEST['user_lastlog_less'] . '<br>';
            }
            if (!empty($_REQUEST['user_reg_more']) && is_numeric($_REQUEST['user_reg_more'])) {
                $f_user_reg_more = (int)trim($_REQUEST['user_reg_more']);
                $time            = time() - (60 * 60 * 24 * $f_user_reg_more);
                if ($time > 0) {
                    $criteria->add(new Criteria('user_regdate', $time, '<'));
                }
                $requete_pagenav .= '&user_regdate=' . htmlspecialchars($_REQUEST['user_regdate']);
                $requete_search .= 'enregistre apres : ' . $_REQUEST['user_reg_more'] . '<br>';
            }
            if (!empty($_REQUEST['user_reg_less']) && is_numeric($_REQUEST['user_reg_less'])) {
                $f_user_reg_less = (int)$_REQUEST['user_reg_less'];
                $time            = time() - (60 * 60 * 24 * $f_user_reg_less);
                if ($time > 0) {
                    $criteria->add(new Criteria('user_regdate', $time, '>'));
                }
                $requete_pagenav .= '&user_reg_less=' . htmlspecialchars($_REQUEST['user_reg_less']);
                $requete_search .= 'enregistre avant : ' . $_REQUEST['user_reg_less'] . '<br>';
            }
            if (!empty($_REQUEST['user_posts_more']) && is_numeric($_REQUEST['user_posts_more'])) {
                $criteria->add(new Criteria('posts', (int)$_REQUEST['user_posts_more'], '>'));
                $requete_pagenav .= '&user_posts_more=' . htmlspecialchars($_REQUEST['user_posts_more']);
                $requete_search .= 'posts plus de : ' . $_REQUEST['user_posts_more'] . '<br>';
            }
            if (!empty($_REQUEST['user_posts_less']) && is_numeric($_REQUEST['user_posts_less'])) {
                $criteria->add(new Criteria('posts', (int)$_REQUEST['user_posts_less'], '<'));
                $requete_pagenav .= '&user_posts_less=' . htmlspecialchars($_REQUEST['user_posts_less']);
                $requete_search .= 'post moins de : ' . $_REQUEST['user_posts_less'] . '<br>';
            }
            if (isset($_REQUEST['user_mailok'])) {
                if ($_REQUEST['user_mailok'] === 'mailng') {
                    $criteria->add(new Criteria('user_mailok', 0));
                } elseif ($_REQUEST['user_mailok'] === 'mailok') {
                    $criteria->add(new Criteria('user_mailok', 1));
                } else {
                    $criteria->add(new Criteria('user_mailok', 0, '>='));
                }
                $requete_pagenav .= '&user_mailok=' . htmlspecialchars($_REQUEST['user_mailok']);
                $requete_search .= 'accept email : ' . $_REQUEST['user_mailok'] . '<br>';
            }
            if (isset($_REQUEST['user_type']) && !empty($_REQUEST['user_type'])) {
                if ($_REQUEST['user_type'] === 'inactv') {
                    $criteria->add(new Criteria('level', 0, '='));
                    $user_type = 'inactv';
                    $requete_search .= 'actif ou inactif : inactif<br>';
                } elseif ($_REQUEST['user_type'] === 'actv') {
                    $criteria->add(new Criteria('level', 0, '>'));
                    $user_type = 'actv';
                    $requete_search .= 'actif ou inactif : actif<br>';
                }
                $requete_pagenav .= '&user_type=' . htmlspecialchars($_REQUEST['user_type']);
            } else {
                $criteria->add(new Criteria('level', 0, '>='));
                $user_type = '';
                $requete_search .= 'actif ou inactif : admin et user<br>';
            }
            //$groups = empty($_REQUEST['selgroups']) ? array() : array_map("intval", $_REQUEST['selgroups']);
            $validsort = array('uname', 'email', 'last_login', 'user_regdate', 'posts');
            if (isset($_REQUEST['user_sort'])) {
                $sort = (!in_array($_REQUEST['user_sort'], $validsort)) ? 'user_regdate' : $_REQUEST['user_sort'];
                $requete_pagenav .= '&user_sort=' . htmlspecialchars($_REQUEST['user_sort']);
                $requete_search .= 'order by : ' . $sort . '<br>';
            } else {
                $sort = 'user_regdate';
                $requete_pagenav .= '&user_sort=user_regdate';
                $requete_search .= 'order by : ' . $sort . '<br>';
            }
            $order = 'DESC';
            if (isset($_REQUEST['user_order']) && $_REQUEST['user_order'] === 'ASC') {
                $requete_pagenav .= '&user_order=ASC';
                $requete_search .= 'tris : ' . $order . '<br>';
            } else {
                //$order = "ASC";
                $requete_pagenav .= '&user_order=DESC';
                $requete_search .= 'tris : ' . $order . '<br>';
            }
            $user_limit = xoops_getModuleOption('users_pager', 'system');
            if (isset($_REQUEST['user_limit'])) {
                $user_limit = $_REQUEST['user_limit'];
                $requete_pagenav .= '&user_limit=' . htmlspecialchars($_REQUEST['user_limit']);
                $requete_search .= 'limit : ' . $user_limit . '<br>';
            } else {
                $requete_pagenav .= '&user_limit=' . xoops_getModuleOption('users_pager', 'system');
                $requete_search .= 'limit : ' . $user_limit . '<br>';
            }
            $start = (!empty($_REQUEST['start'])) ? (int)$_REQUEST['start'] : 0;
            if (isset($_REQUEST['selgroups'])) {
                if ($_REQUEST['selgroups'] != 0) {
                    if (count($_REQUEST['selgroups']) == 1) {
                        $groups = array( 0 => (int) $_REQUEST['selgroups']);
                    } else {
                        $groups = array_map('intval', $_REQUEST['selgroups']);
                    }
                } else {
                    $groups = array();
                }
                $requete_pagenav .= '&selgroups=' . htmlspecialchars($_REQUEST['selgroups']);
            } else {
                $groups = array();
            }
            //print_r($groups);
            /* @var XoopsMemberHandler $member_handler */
            $member_handler = xoops_getHandler('member');
            if (empty($groups)) {
                $users_count = $member_handler->getUserCount();
            } else {
                $users_count = $member_handler->getUserCountByGroupLink($groups, $criteria);
            }
            if ($start < $users_count) {
                echo sprintf(_AM_SYSTEM_USERS_USERSFOUND, $users_count) . '<br>';
                $criteria->setSort($sort);
                $criteria->setOrder($order);
                $criteria->setLimit($user_limit);
                $criteria->setStart($start);
                $users_arr = $member_handler->getUsersByGroupLink($groups, $criteria, true);
                $ucount    = 0;
            }
            $xoopsTpl->assign('users_count', $users_count);
            $xoopsTpl->assign('users_display', true);
            //User limit
            //$user_limit = (!isset($_REQUEST['user_limit'])) ? 20 : $_REQUEST['user_limit'];
            //User type
            $user_type = (!isset($_REQUEST['user_type'])) ? '' : $_REQUEST['user_type'];
            //selgroups
            $selgroups = (!isset($_REQUEST['selgroups'])) ? '' : $_REQUEST['selgroups'];
            $user_uname = (!isset($_REQUEST['user_uname'])) ? '' : $_REQUEST['user_uname'];
            //Form tris
            $form          = '<form action="admin.php?fct=users" method="post">
                    ' . _AM_SYSTEM_USERS_SEARCH_USER . '<input type="text" name="user_uname" value="' . $myts->htmlSpecialChars($user_uname) . '" size="15">
                    <select name="selgroups">
                        <option value="" selected>' . _AM_SYSTEM_USERS_ALLGROUP . '</option>';
            /* @var XoopsGroupHandler $group_handler */
            $group_handler = xoops_getHandler('group');
            $group_arr     = $group_handler->getObjects();
            foreach (array_keys($group_arr) as $i) {
                if ($group_arr[$i]->getVar('groupid') != XOOPS_GROUP_ANONYMOUS) {
                    $form .= '<option value="' . $group_arr[$i]->getVar('groupid') . '"  ' . ($selgroups == $group_arr[$i]->getVar('groupid') ? ' selected' : '') . '>' . $group_arr[$i]->getVar('name') . '</option>';
                }
            }
            $form .= '</select> 
                <select name="user_type">
                    <option value="" ' . ($user_type === '' ? ' selected' : '') . '>' . _AM_SYSTEM_USERS_ALLUSER . '</option>
                    <option value="actv" ' . ($user_type === 'actv' ? ' selected' : '') . '>' . _AM_SYSTEM_USERS_ACTIVEUSER . '</option>
                    <option value="inactv" ' . ($user_type === 'inactv' ? ' selected' : '') . '>' . _AM_SYSTEM_USERS_INACTIVEUSER . '</option>
                </select> 
                <select name="user_limit">
                    <option value="20" ' . ($user_limit == 20 ? ' selected' : '') . '>20</option>
                    <option value="50" ' . ($user_limit == 50 ? ' selected' : '') . '>50</option>
                    <option value="100" ' . ($user_limit == 100 ? ' selected' : '') . '>100</option>
                </select> 
                <input type="hidden" name="user_uname_match" value="XOOPS_MATCH_START" />
                <input type="submit" value="' . _AM_SYSTEM_USERS_SEARCH . '" name="speed_search"> 
                <input type="submit" value="' . _AM_SYSTEM_USERS_ADVANCED_SEARCH . '" name="complet_search"></form>
                ';
            //select groupe
            $form_select_groups = '<select  name="selgroups" id="selgroups"   style="display:none;"><option value="">---------</option>';
            //$module_array[0] = _AM_SYSTEM_USERS_COMMENTS_FORM_ALL_MODS;
            $group_handler = xoops_getHandler('group');
            $group_arr     = $group_handler->getObjects();
            foreach (array_keys($group_arr) as $i) {
                if ($group_arr[$i]->getVar('groupid') != XOOPS_GROUP_ANONYMOUS) {
                    $form_select_groups .= '<option value="' . $group_arr[$i]->getVar('groupid') . '"  ' . ($selgroups == $group_arr[$i]->getVar('groupid') ? ' selected' : '') . '>' . $group_arr[$i]->getVar('name') . '</option>';
                }
            }
            $form_select_groups .= '</select><input type="hidden" name="op" value="users_add_delete_group">';
            $xoopsTpl->assign('form_sort', $form);
            $xoopsTpl->assign('form_select_groups', $form_select_groups);
            // add token to render in template
            $tokenElement = new XoopsFormHiddenToken();
            $token = $tokenElement->render();
            $xoopsTpl->assign('form_token', $token);
            //echo $requete_search;
            if ($users_count > 0) {
                //echo $requete_search;
                foreach (array_keys($users_arr) as $i) {
                    //Display group
                    $user_group = $member_handler->getGroupsByUser($users_arr[$i]->getVar('uid'));
                    if (in_array(XOOPS_GROUP_ADMIN, $user_group)) {
                        $users['group'] = system_AdminIcons('xoops/group_1.png');
                        //$users['icon'] = '<img src="'.XOOPS_URL.'/modules/system/images/icons/admin.png" alt="'._AM_SYSTEM_USERS_ADMIN.'" title="'._AM_SYSTEM_USERS_ADMIN.'" />';
                        $users['checkbox_user'] = false;
                    } else {
                        $users['group'] = system_AdminIcons('xoops/group_2.png');
                        //$users['icon'] = '<img src="'.XOOPS_URL.'/modules/system/images/icons/user.png" alt="'._AM_SYSTEM_USERS_USER.'" title="'._AM_SYSTEM_USERS_USER.'" />';
                        $users['checkbox_user'] = true;
                    }
                    $users['uid']         = $users_arr[$i]->getVar('uid');
                    $users['name']        = $users_arr[$i]->getVar('name');
                    $users['uname']       = $users_arr[$i]->getVar('uname');
                    $users['email']       = $users_arr[$i]->getVar('email');
                    $users['url']         = $users_arr[$i]->getVar('url');
                    $users['user_avatar'] = ($users_arr[$i]->getVar('user_avatar') === 'blank.gif') ? system_AdminIcons('anonymous.png') : XOOPS_URL . '/uploads/' . $users_arr[$i]->getVar('user_avatar');
                    $users['reg_date']    = formatTimestamp($users_arr[$i]->getVar('user_regdate'), 'm');
                    if ($users_arr[$i]->getVar('last_login') > 0) {
                        $users['last_login'] = formatTimestamp($users_arr[$i]->getVar('last_login'), 'm');
                    } else {
                        $users['last_login'] = _AM_SYSTEM_USERS_NOT_CONNECT;
                    }
                    $users['user_level'] = $users_arr[$i]->getVar('level');
                    $users['user_icq']   = $users_arr[$i]->getVar('user_icq');
                    $users['user_aim']   = $users_arr[$i]->getVar('user_aim');
                    $users['user_yim']   = $users_arr[$i]->getVar('user_yim');
                    $users['user_msnm']  = $users_arr[$i]->getVar('user_msnm');
                    $users['posts'] = $users_arr[$i]->getVar('posts');
                    $xoopsTpl->append_by_ref('users', $users);
                    $xoopsTpl->append_by_ref('users_popup', $users);
                    unset($users);
                }
            } else {
                $xoopsTpl->assign('users_no_found', true);
            }
            if ($users_count > $user_limit) {
                include_once XOOPS_ROOT_PATH . '/class/pagenav.php';
                $nav = new XoopsPageNav($users_count, $user_limit, $start, 'start', 'fct=users&op=default' . $requete_pagenav);
                $xoopsTpl->assign('nav', $nav->renderNav());
            }
        }
        break;
}
// Call Footer
xoops_cp_footer();
 
  |