0

我一直在使用 Land of Coder 开发的 K2 Scroller 模块。当我使用此模块在项目视图中显示相同类别的项目时,该模块按创建日期的升序显示项目,这是后端模块参数设置中默认且唯一可用的设置。但是,我希望模块按日期降序显示项目。所以我选择在帮助程序中编辑默认代码,我想它是用来根据后端设置处理项目的。这是我认为控制顺序的帮助文件中的代码部分:

public function __getList( $params ){
            global $mainframe;

                         /*some irrelevant code removed*/

                        $condition     = $this->buildConditionQuery( $params );
            $limitDescriptionBy = $params->get('limit_description_by','char');
            $ordering      = $params->get( 'k2_ordering', 'created_desc'); 
            $limit         = $params->get( 'limit_items',  5 );
            $ordering      = str_replace( '_', '  ', $ordering );
            $my            = &JFactory::getUser();
            $aid           = $my->get( 'aid', 0 );

                        /*some irrelevant code removed*/

            $extraURL       = $params->get('open_target')!='modalbox'?'':'&tmpl=component'; 
            $excludeIds     = $params->get('exclude_ids', '');
            $db     = &JFactory::getDBO();
            $date   =& JFactory::getDate();
            $now    = $date->toMySQL();
            $dateFormat = $params->get('date_format', 'DATE_FORMAT_LC3');

            $limitDescriptionBy = $params->get('limit_description_by','char');
            $isAuthor= $params->get('itemAuthor',0);
            require_once ( JPath::clean(JPATH_SITE.'/components/com_k2/helpers/route.php') );
            $query = "SELECT a.*, cr.rating_sum/cr.rating_count as rating, c.name as categoryname,
                            c.id as categoryid, c.alias as categoryalias, c.params as categoryparams, cc.commentcount as commentcount".
                    " FROM #__k2_items as a".
                        " LEFT JOIN #__k2_categories c ON c.id = a.catid" .
                        " LEFT JOIN #__k2_rating as cr ON a.id = cr.itemid".
                        " LEFT JOIN (select cm.itemid  as id, count(cm.id) as commentcount from #__k2_comments as cm
                                                                    where cm.published=1 group by cm.itemid) as cc on a.id = cc.id";

            $query .= " WHERE a.published = 1"
                        . " AND a.access get('featured_items_show','0') == 0 ){
                $query.= " AND a.featured != 1";
            } elseif(  $params->get('featured_items_show','0') == 2 ) {
                $query.= " AND a.featured = 1";
            }
            if( trim($excludeIds) ){
                $query .= " AND a.id NOT IN(".$excludeIds.") ";
            }
            $query .=  $condition . ' ORDER BY ' . $ordering;   
            $query .=  $limit ? ' LIMIT ' . $limit : '';

            $db->setQuery($query);
            $data = $db->loadObjectlist();

            /*some irrelevant code removed*/

                        return $data;   
        }


        /**
         * build condition query base parameter  
         * 
         * @param JParameter $params;
         * @return string.
         */
        public  function buildConditionQuery( $params ){
            $source = trim($params->get( 'k2_source', 'k2_category' ) );
            if( $source == 'k2_category' ){
                $catids = $params->get( 'k2_category','');

                if( !$catids ){
                    return '';
                }
                $catids = !is_array($catids) ? $catids : '"'.implode('","',$catids).'"';
                $condition = ' AND  a.catid IN( '.$catids.' )';
            } else {
                $ids = preg_split('/,/',$params->get( 'k2_items_ids',''));  
                $tmp = array();
                foreach( $ids as $id ){
                    $tmp[] = (int) trim($id);
                }
                $condition = " AND a.id IN('". implode( "','", $tmp ) ."')";
            }
            return $condition;
        }

我是在编辑代码的正确部分还是遗漏了其他内容。

我期待着你的帮助

谢谢。

4

1 回答 1

0

也许最好的方法是修改模块的 xml 文件。

我查看了 Lof K2Scroller 的代码(Joomla 2.5 的 v 2.2)并且有不同的排序选项。

但是,如果您想修改默认选项,您在正确的文件中,只需将 'created_desc' 替换为 'created_asc' 。

于 2012-03-31T15:11:02.307 回答