194 lines
4.6 KiB
PHP
194 lines
4.6 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* @package Joomla.Administrator
|
||
|
* @subpackage com_users
|
||
|
*
|
||
|
* @copyright Copyright (C) 2005 - 2013 Open Source Matters, Inc. All rights reserved.
|
||
|
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||
|
*/
|
||
|
|
||
|
defined('_JEXEC') or die;
|
||
|
|
||
|
/**
|
||
|
* Users component helper.
|
||
|
*
|
||
|
* @package Joomla.Administrator
|
||
|
* @subpackage com_users
|
||
|
* @since 1.6
|
||
|
*/
|
||
|
class UsersHelper
|
||
|
{
|
||
|
/**
|
||
|
* @var JObject A cache for the available actions.
|
||
|
* @since 1.6
|
||
|
*/
|
||
|
protected static $actions;
|
||
|
|
||
|
/**
|
||
|
* Configure the Linkbar.
|
||
|
*
|
||
|
* @param string $vName The name of the active view.
|
||
|
*
|
||
|
* @return void
|
||
|
*
|
||
|
* @since 1.6
|
||
|
*/
|
||
|
public static function addSubmenu($vName)
|
||
|
{
|
||
|
JHtmlSidebar::addEntry(
|
||
|
JText::_('COM_USERS_SUBMENU_USERS'),
|
||
|
'index.php?option=com_users&view=users',
|
||
|
$vName == 'users'
|
||
|
);
|
||
|
|
||
|
// Groups and Levels are restricted to core.admin
|
||
|
$canDo = self::getActions();
|
||
|
|
||
|
if ($canDo->get('core.admin'))
|
||
|
{
|
||
|
JHtmlSidebar::addEntry(
|
||
|
JText::_('COM_USERS_SUBMENU_GROUPS'),
|
||
|
'index.php?option=com_users&view=groups',
|
||
|
$vName == 'groups'
|
||
|
);
|
||
|
JHtmlSidebar::addEntry(
|
||
|
JText::_('COM_USERS_SUBMENU_LEVELS'),
|
||
|
'index.php?option=com_users&view=levels',
|
||
|
$vName == 'levels'
|
||
|
);
|
||
|
JHtmlSidebar::addEntry(
|
||
|
JText::_('COM_USERS_SUBMENU_NOTES'),
|
||
|
'index.php?option=com_users&view=notes',
|
||
|
$vName == 'notes'
|
||
|
);
|
||
|
|
||
|
$extension = JFactory::getApplication()->input->getString('extension');
|
||
|
JHtmlSidebar::addEntry(
|
||
|
JText::_('COM_USERS_SUBMENU_NOTE_CATEGORIES'),
|
||
|
'index.php?option=com_categories&extension=com_users',
|
||
|
$vName == 'categories' || $extension == 'com_users'
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets a list of the actions that can be performed.
|
||
|
*
|
||
|
* @return JObject
|
||
|
*
|
||
|
* @since 1.6
|
||
|
* @todo Refactor to work with notes
|
||
|
*/
|
||
|
public static function getActions()
|
||
|
{
|
||
|
if (empty(self::$actions))
|
||
|
{
|
||
|
$user = JFactory::getUser();
|
||
|
self::$actions = new JObject;
|
||
|
|
||
|
$actions = JAccess::getActions('com_users');
|
||
|
|
||
|
foreach ($actions as $action)
|
||
|
{
|
||
|
self::$actions->set($action->name, $user->authorise($action->name, 'com_users'));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return self::$actions;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get a list of filter options for the blocked state of a user.
|
||
|
*
|
||
|
* @return array An array of JHtmlOption elements.
|
||
|
*
|
||
|
* @since 1.6
|
||
|
*/
|
||
|
public static function getStateOptions()
|
||
|
{
|
||
|
// Build the filter options.
|
||
|
$options = array();
|
||
|
$options[] = JHtml::_('select.option', '0', JText::_('JENABLED'));
|
||
|
$options[] = JHtml::_('select.option', '1', JText::_('JDISABLED'));
|
||
|
|
||
|
return $options;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get a list of filter options for the activated state of a user.
|
||
|
*
|
||
|
* @return array An array of JHtmlOption elements.
|
||
|
*
|
||
|
* @since 1.6
|
||
|
*/
|
||
|
public static function getActiveOptions()
|
||
|
{
|
||
|
// Build the filter options.
|
||
|
$options = array();
|
||
|
$options[] = JHtml::_('select.option', '0', JText::_('COM_USERS_ACTIVATED'));
|
||
|
$options[] = JHtml::_('select.option', '1', JText::_('COM_USERS_UNACTIVATED'));
|
||
|
|
||
|
return $options;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get a list of the user groups for filtering.
|
||
|
*
|
||
|
* @return array An array of JHtmlOption elements.
|
||
|
*
|
||
|
* @since 1.6
|
||
|
*/
|
||
|
public static function getGroups()
|
||
|
{
|
||
|
$db = JFactory::getDbo();
|
||
|
$query = $db->getQuery(true)
|
||
|
->select('a.id AS value')
|
||
|
->select('a.title AS text')
|
||
|
->select('COUNT(DISTINCT b.id) AS level')
|
||
|
->from('#__usergroups as a')
|
||
|
->join('LEFT', '#__usergroups AS b ON a.lft > b.lft AND a.rgt < b.rgt')
|
||
|
->group('a.id, a.title, a.lft, a.rgt')
|
||
|
->order('a.lft ASC');
|
||
|
$db->setQuery($query);
|
||
|
|
||
|
try
|
||
|
{
|
||
|
$options = $db->loadObjectList();
|
||
|
}
|
||
|
catch (RuntimeException $e)
|
||
|
{
|
||
|
JError::raiseNotice(500, $e->getMessage());
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
foreach ($options as &$option)
|
||
|
{
|
||
|
$option->text = str_repeat('- ', $option->level).$option->text;
|
||
|
}
|
||
|
|
||
|
return $options;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Creates a list of range options used in filter select list
|
||
|
* used in com_users on users view
|
||
|
*
|
||
|
* @return array
|
||
|
*
|
||
|
* @since 2.5
|
||
|
*/
|
||
|
public static function getRangeOptions()
|
||
|
{
|
||
|
$options = array(
|
||
|
JHtml::_('select.option', 'today', JText::_('COM_USERS_OPTION_RANGE_TODAY')),
|
||
|
JHtml::_('select.option', 'past_week', JText::_('COM_USERS_OPTION_RANGE_PAST_WEEK')),
|
||
|
JHtml::_('select.option', 'past_1month', JText::_('COM_USERS_OPTION_RANGE_PAST_1MONTH')),
|
||
|
JHtml::_('select.option', 'past_3month', JText::_('COM_USERS_OPTION_RANGE_PAST_3MONTH')),
|
||
|
JHtml::_('select.option', 'past_6month', JText::_('COM_USERS_OPTION_RANGE_PAST_6MONTH')),
|
||
|
JHtml::_('select.option', 'past_year', JText::_('COM_USERS_OPTION_RANGE_PAST_YEAR')),
|
||
|
JHtml::_('select.option', 'post_year', JText::_('COM_USERS_OPTION_RANGE_POST_YEAR')),
|
||
|
);
|
||
|
return $options;
|
||
|
}
|
||
|
}
|