Files
@ c7d7e38b2269
Branch filter:
Location: hot67beta/administrator/components/com_installer/models/modules.php
c7d7e38b2269
3.2 KiB
text/x-php
Initial import of the site.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 | <?php
/**
* @version $Id: modules.php 10710 2008-08-21 10:08:12Z eddieajau $
* @package Joomla
* @subpackage Menus
* @copyright Copyright (C) 2005 - 2008 Open Source Matters. All rights reserved.
* @license GNU/GPL, see LICENSE.php
* Joomla! is free software. This version may have been modified pursuant to the
* GNU General Public License, and as distributed it includes or is derivative
* of works licensed under the GNU General Public License or other free or open
* source software licenses. See COPYRIGHT.php for copyright notices and
* details.
*/
// Import library dependencies
require_once(dirname(__FILE__).DS.'extension.php');
/**
* Extension Manager Modules Model
*
* @package Joomla
* @subpackage Installer
* @since 1.5
*/
class InstallerModelModules extends InstallerModel
{
/**
* Extension Type
* @var string
*/
var $_type = 'module';
/**
* Overridden constructor
* @access protected
*/
function __construct()
{
global $mainframe;
// Call the parent constructor
parent::__construct();
// Set state variables from the request
$this->setState('filter.string', $mainframe->getUserStateFromRequest( 'com_installer.modules.string', 'filter', '', 'string' ));
$this->setState('filter.client', $mainframe->getUserStateFromRequest( 'com_installer.modules.client', 'client', -1, 'int' ));
}
function _loadItems()
{
global $mainframe, $option;
$db = &JFactory::getDBO();
$and = null;
if ($this->_state->get('filter.client') < 0) {
if ($search = $this->_state->get('filter.string')) {
$and = ' AND title LIKE '.$db->Quote( '%'.$db->getEscaped( $search, true ).'%', false );
}
} else {
if ($search = $this->_state->get('filter.string'))
{
$and = ' AND client_id = '.(int)$this->_state->get('filter.client');
$and .= ' AND title LIKE '.$db->Quote( '%'.$db->getEscaped( $search, true ).'%', false );
}
else {
$and = ' AND client_id = '.(int)$this->_state->get('filter.client');
}
}
$query = 'SELECT id, module, client_id, title, iscore' .
' FROM #__modules' .
' WHERE module LIKE "mod_%" ' .
$and .
' GROUP BY module, client_id' .
' ORDER BY iscore, client_id, module';
$db->setQuery($query);
$rows = $db->loadObjectList();
$n = count($rows);
for ($i = 0; $i < $n; $i ++) {
$row = & $rows[$i];
// path to module directory
if ($row->client_id == "1") {
$moduleBaseDir = JPATH_ADMINISTRATOR.DS."modules";
} else {
$moduleBaseDir = JPATH_SITE.DS."modules";
}
// xml file for module
$xmlfile = $moduleBaseDir . DS . $row->module .DS. $row->module.".xml";
if (file_exists($xmlfile))
{
if ($data = JApplicationHelper::parseXMLInstallFile($xmlfile)) {
foreach($data as $key => $value) {
$row->$key = $value;
}
}
}
}
$this->setState('pagination.total', $n);
// if the offset is greater than the total, then can the offset
if($this->_state->get('pagination.offset') > $this->_state->get('pagination.total')) {
$this->setState('pagination.offset',0);
}
if($this->_state->get('pagination.limit') > 0) {
$this->_items = array_slice( $rows, $this->_state->get('pagination.offset'), $this->_state->get('pagination.limit') );
} else {
$this->_items = $rows;
}
}
}
|