<?php /** * @package Joomla.Site * @subpackage com_content_custom * * @copyright Copyright (C) 2005 - 2019 Open Source Matters, Inc. All rights reserved. * @license GNU General Public License version 2 or later; see LICENSE.txt */ defined('_JEXEC') or die; /** * Content Component Query Helper * * @since 1.5 */ class ContentCustomHelperQuery { /** * Translate an order code to a field for secondary category ordering. * * @param string $orderby The ordering code. * @param string $orderDate The ordering code for the date. * * @return string The SQL field(s) to order by. * * @since 1.5 */ public static function orderbySecondary($orderby, $orderDate = 'created') { $queryDate = self::getQueryDate($orderDate); switch ($orderby) { case 'date' : $orderby = $queryDate; break; case 'rdate' : $orderby = $queryDate . ' DESC '; break; case 'alpha' : $orderby = 'a.title'; break; case 'ralpha' : $orderby = 'a.title DESC'; break; case 'hits' : $orderby = 'a.hits DESC'; break; case 'rhits' : $orderby = 'a.hits'; break; case 'order' : $orderby = 'a.ordering'; break; case 'rorder' : $orderby = 'a.ordering DESC'; break; case 'author' : $orderby = 'author'; break; case 'rauthor' : $orderby = 'author DESC'; break; case 'front' : $orderby = 'a.featured DESC, fp.ordering, ' . $queryDate . ' DESC '; break; case 'random' : $orderby = JFactory::getDbo()->getQuery(true)->Rand(); break; case 'vote' : $orderby = 'a.id DESC '; if (JPluginHelper::isEnabled('content', 'vote')) { $orderby = 'rating_count DESC '; } break; case 'rvote' : $orderby = 'a.id ASC '; if (JPluginHelper::isEnabled('content', 'vote')) { $orderby = 'rating_count ASC '; } break; case 'rank' : $orderby = 'a.id DESC '; if (JPluginHelper::isEnabled('content', 'vote')) { $orderby = 'rating DESC '; } break; case 'rrank' : $orderby = 'a.id ASC '; if (JPluginHelper::isEnabled('content', 'vote')) { $orderby = 'rating ASC '; } break; default : $orderby = 'a.ordering'; break; } return $orderby; } /** * Translate an order code to a field for primary category ordering. * * @param string $orderDate The ordering code. * * @return string The SQL field(s) to order by. * * @since 1.6 */ public static function getQueryDate($orderDate) { $db = JFactory::getDbo(); switch ($orderDate) { case 'modified' : $queryDate = ' CASE WHEN a.modified = ' . $db->quote($db->getNullDate()) . ' THEN a.created ELSE a.modified END'; break; // Use created if publish_up is not set case 'published' : $queryDate = ' CASE WHEN a.publish_up = ' . $db->quote($db->getNullDate()) . ' THEN a.created ELSE a.publish_up END '; break; case 'unpublished' : $queryDate = ' CASE WHEN a.publish_down = ' . $db->quote($db->getNullDate()) . ' THEN a.created ELSE a.publish_down END '; break; case 'created' : default : $queryDate = ' a.created '; break; } return $queryDate; } }