2011-07-14 08:59:32 +10:00
|
|
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class is used to sort multiple dimension arrays.
|
|
|
|
*
|
|
|
|
* @package lnApp
|
|
|
|
* @subpackage Sort
|
|
|
|
* @category Helpers
|
|
|
|
* @author Deon George
|
|
|
|
* @copyright (c) 2010 Deon George
|
|
|
|
* @license http://dev.leenooks.net/license.html
|
|
|
|
* @uses Style
|
|
|
|
*/
|
|
|
|
class lnApp_Sort {
|
|
|
|
/**
|
|
|
|
* Sort a multi dimensional array.
|
|
|
|
*
|
|
|
|
* @param array Multi demension array passed by reference
|
|
|
|
* @param string Comma delimited string of sort keys.
|
|
|
|
* @param boolean Whether to reverse sort.
|
|
|
|
* @return array Sorted multi demension array.
|
|
|
|
*/
|
2011-09-28 16:46:22 +10:00
|
|
|
public static function MAsort(&$data,$sortby,$rev=0) {
|
|
|
|
// if the array to sort is null or empty, or our sortby is bad
|
|
|
|
if (! preg_match('/^[a-zA-Z0-9_]+(\([a-zA-Z0-9_,]*\))?$/',$sortby) || ! $data)
|
2011-07-14 08:59:32 +10:00
|
|
|
return;
|
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
$code = '$c=0;';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
|
|
|
foreach (explode(',',$sortby) as $key) {
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'if (is_object($a) || is_object($b)) {';
|
|
|
|
foreach (array('a','b') as $x) {
|
|
|
|
$code .= 'if (is_array($'.$x.'->'.$key.')) {';
|
|
|
|
$code .= 'asort($'.$x.'->'.$key.');';
|
|
|
|
$code .= '$x'.$x.' = array_shift($'.$x.'->'.$key.');';
|
|
|
|
$code .= '} else';
|
|
|
|
$code .= '$x'.$x.' = $'.$x.'->'.$key.';';
|
|
|
|
}
|
|
|
|
|
|
|
|
$code .= 'if ($xa != $xb)';
|
2011-08-31 15:09:03 +10:00
|
|
|
if ($rev)
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'return ($xa < $xb ? 1 : -1);';
|
2011-08-31 15:09:03 +10:00
|
|
|
else
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'return ($xa > $xb ? 1 : -1);';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= '} else {';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
foreach (array('a','b') as $x)
|
|
|
|
$code .= '$'.$x.' = array_change_key_case($'.$x.');';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
|
|
|
$key = strtolower($key);
|
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'if ((! isset($a[\''.$key.'\'])) && isset($b[\''.$key.'\'])) return 1;';
|
|
|
|
$code .= 'if (isset($a[\''.$key.'\']) && (! isset($b[\''.$key.'\']))) return -1;';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'if ((isset($a[\''.$key.'\'])) && (isset($b[\''.$key.'\']))) {';
|
|
|
|
foreach (array('a','b') as $x) {
|
|
|
|
$code .= 'if (is_array($'.$x.'[\''.$key.'\'])) {';
|
|
|
|
$code .= 'asort($'.$x.'[\''.$key.'\']);';
|
|
|
|
$code .= '$x'.$x.' = array_shift($'.$x.'[\''.$key.'\']);';
|
|
|
|
$code .= '} else';
|
|
|
|
$code .= '$x'.$x.' = $'.$x.'[\''.$key.'\'];';
|
|
|
|
}
|
2011-08-31 15:09:03 +10:00
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'if ($xa != $xb)';
|
|
|
|
$code .= 'if (is_numeric($xa) && is_numeric($xb)) {';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
|
|
|
if ($rev)
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'return ($xa < $xb ? 1 : -1);';
|
2011-08-31 15:09:03 +10:00
|
|
|
else
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'return ($xa > $xb ? 1 : -1);';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= '} else {';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
|
|
|
if ($rev)
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'if (($c = strcasecmp($xb,$xa)) != 0) return $c;';
|
2011-08-31 15:09:03 +10:00
|
|
|
else
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= 'if (($c = strcasecmp($xa,$xb)) != 0) return $c;';
|
2011-08-31 15:09:03 +10:00
|
|
|
|
2011-09-28 16:46:22 +10:00
|
|
|
$code .= '}}}';
|
2011-07-14 08:59:32 +10:00
|
|
|
}
|
2011-08-31 15:09:03 +10:00
|
|
|
|
|
|
|
$code .= 'return $c;';
|
|
|
|
|
|
|
|
$result = create_function('$a, $b',$code);
|
2011-07-14 08:59:32 +10:00
|
|
|
|
2011-08-31 15:09:03 +10:00
|
|
|
uasort($data,$result);
|
2011-07-14 08:59:32 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|