Current Path : /var/www/html/clients/kampol.e-nk.ru/OLD/modules/ |
Current File : /var/www/html/clients/kampol.e-nk.ru/OLD/modules/mod_sections.php |
<?php /** * @version $Id: mod_sections.php 5970 2006-12-10 21:58:09Z friesengeist $ * @package Joomla * @copyright Copyright (C) 2005 Open Source Matters. All rights reserved. * @license http://www.gnu.org/copyleft/gpl.html 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. */ global $mosConfig_offset; /// no direct access defined( '_VALID_MOS' ) or die( 'Äîñòóï çàïðåùåí' ); $count = intval( $params->get( 'count', 20 ) ); $access = !$mainframe->getCfg( 'shownoauth' ); $now = _CURRENT_SERVER_TIME; $nullDate = $database->getNullDate(); $query = "SELECT a.id AS id, a.title AS title, COUNT(b.id) as cnt" . "\n FROM #__sections as a" . "\n LEFT JOIN #__content as b ON a.id = b.sectionid" . ( $access ? "\n AND b.access <= " . (int) $my->gid : '' ) . "\n AND ( b.publish_up = " . $database->Quote( $nullDate ) . " OR b.publish_up <= " . $database->Quote( $now ) . " )" . "\n AND ( b.publish_down = " . $database->Quote( $nullDate ) . " OR b.publish_down >= " . $database->Quote( $now ) . " )" . "\n WHERE a.scope = 'content'" . "\n AND a.published = 1" . ( $access ? "\n AND a.access <= " . (int) $my->gid : '' ) . "\n GROUP BY a.id" . "\n HAVING COUNT( b.id ) > 0" . "\n ORDER BY a.ordering" ; $database->setQuery( $query, 0, $count ); $rows = $database->loadObjectList(); if ( $rows ) { // list of sectionids, used to find corresponding Itemids for( $i=0, $n=count( $rows ); $i<$n; $i++ ) { $sids[] = (int) $rows[$i]->id; } // add 0 to the list, to get the Itemid of a global blog section item as a fallback $sids[] = 0; // get Itemids of sections $query = "SELECT m.id AS Itemid, m.componentid AS sectionid" . "\n FROM #__menu AS m" . "\n WHERE ( m.type = 'content_section' OR m.type = 'content_blog_section' )" . "\n AND m.published = 1" . ( $access ? "\n AND m.access <= " . (int) $my->gid : '' ) . "\n AND ( m.componentid=" . implode( " OR m.componentid=", $sids ) . " )" . "\n ORDER BY m.type DESC, m.id DESC" ; $database->setQuery( $query ); $itemids = $database->loadObjectList( 'sectionid' ); ?> <ul> <?php foreach ($rows as $row) { if (isset( $itemids[$row->id] )) { $link = sefRelToAbs( "index.php?option=com_content&task=blogsection&id=". $row->id . "&Itemid=" . $itemids[$row->id]->Itemid ); } else if (isset( $itemids[0] )) { $link = sefRelToAbs( "index.php?option=com_content&task=blogsection&id=". $row->id . "&Itemid=" . $itemids[0]->Itemid ); } else { $link = sefRelToAbs( "index.php?option=com_content&task=blogsection&id=". $row->id ); } ?> <li> <a href="<?php echo $link;?>"> <?php echo $row->title;?></a> </li> <?php } ?> </ul> <?php } ?>