* @version 1.6
*/
require_once dirname(__FILE__) . '/App.inc.php';
require_once dirname(__FILE__) . '/Utilities.inc.php';
require_once dirname(__FILE__) . '/Prefs.inc.php';
class SortOrder {
var $_columns;
var $sort_by;
var $order;
var $asc_widget;
var $desc_widget;
var $default_sort;
var $default_order;
/**
* Constructor. Finds the current sort by and order.
*
* @param string $default_sort If not found elsewhere, this will be the
* current sort by.
* @param string $default_order If not found elsewhere, this will be the
* current order.
*/
function __construct($default_sort = '', $default_order = '')
{
global $CFG;
$this->asc_widget = '';
$this->desc_widget = '';
$this->setDefault($default_sort, $default_order);
$this->default_sort = $default_sort;
$this->default_order = $default_order;
}
/**
* Build an array of valid sort SQL for each DB column. This SQL is reference
* by the name and 'asc' or 'desc'.
*
* @param string $name Reference name for the column this SQL sorts on.
* @param string $asc_sql The sort SQL if $this->order is ascending.
* @param string $desc_sql The sort SQL if $this->order is descending.
*/
function setColumn($name, $asc_sql, $desc_sql)
{
$this->_columns[$name] = array(
'asc' => $asc_sql,
'desc' => $desc_sql
);
}
/**
* Set sort and order values. This is how you set new sort values after
* already declaring a SortOrder object, but expect values to come from
* getFormData.
*
* @param string $default_sort If not found elsewhere, this will be the
* current sort by.
* @param string $default_order If not found elsewhere, this will be the
* current order.
*/
function setDefault($default_sort = '', $default_order = '')
{
// Which column to sort by?
// (1) By GET or POST specification, if available.
// (2) By saved preference, if available.
// (3) By default (provided at class instantiation).
$new_sort_by = getFormData('sort');
if (!empty($new_sort_by)) {
$this->sort_by = $new_sort_by;
Prefs::setValue('sort_by', $this->sort_by, $_SERVER['PHP_SELF']);
} else if (Prefs::exists('sort_by', $_SERVER['PHP_SELF'])) {
$this->sort_by = Prefs::getValue('sort_by', $_SERVER['PHP_SELF']);
} else {
$this->sort_by = $default_sort;
}
// Which sort order to use?
// (1) By GET or POST specification, if available.
// (2) By saved preference, if available.
// (3) By default (provided at class instanciation).
$new_order = getFormData('order');
if (!empty($new_order)) {
$this->order = $new_order;
Prefs::setValue('sort_order', $this->order, $_SERVER['PHP_SELF']);
} else if (Prefs::exists('sort_order', $_SERVER['PHP_SELF'])) {
$this->order = Prefs::getValue('sort_order', $_SERVER['PHP_SELF']);
} else {
$this->order = $default_order;
}
}
/**
* Set sort and order values. This is how you set new sort values after
* already declaring a SortOrder object. This will ignore getFormData values.
*
* @param string $col The database column to sort by.
* @param string $col_name The human-readable title of the column.
* @param string $default_order The default order for this column (ASC,
* for example, for an alphabetical sort)
*/
function set($sort = null, $order = null)
{
// Set new sort value.
if (isset($sort)) {
$this->sort_by = $sort;
Prefs::setValue('sort_by', $this->sort_by, $_SERVER['PHP_SELF']);
}
// Set new order value.
if (isset($order)) {
$this->order = $order;
Prefs::setValue('sort_order', $this->order, $_SERVER['PHP_SELF']);
}
}
/**
* Returns the SQL code to sort by set column and set order.
*/
function getSortOrderSQL()
{
if (!isset($this->_columns[strtolower($this->sort_by)])) {
$this->sort_by = $this->default_sort;
$this->order = $this->default_order;
}
if (!isset($this->_columns[strtolower($this->sort_by)][strtolower($this->order)])) {
$this->order = 'ASC';
}
if (!empty($this->_columns[strtolower($this->sort_by)][strtolower(strtolower($this->order))])) {
return ' ORDER BY ' . mysql_real_escape_string($this->_columns[strtolower($this->sort_by)][strtolower(strtolower($this->order))]);
} else {
logMsg(sprintf('Could not find SQL to sort by %s %s.', $this->sort_by, $this->order), LOG_WARNING, __FILE__, __LINE__);
return '';
}
}
/**
* Prints a link for a column header with URL sort determining logic.
*
* @param string $col The database column to sort by.
* @param string $col_name The human-readable title of the column.
* @param string $default_order The default order for this column (ASC,
* for example, for an alphabetical sort)
*/
function printSortHeader($col, $col_name, $default_order='ASC')
{
if ($this->sort_by == $col) {
if (strtolower($this->order) == 'desc') {
?>">desc_widget; ?>">asc_widget; ?>">