diff options
author | Steve Clay <steve@mrclay.org> | 2012-10-25 06:54:30 -0700 |
---|---|---|
committer | Steve Clay <steve@mrclay.org> | 2012-10-25 06:54:30 -0700 |
commit | bdb6d69bc9d81b3cef39bc1b60df731ee81844d3 (patch) | |
tree | c8a1742130d7ef3e72b7872bd22e7868eff5e16c /engine/classes/ElggMenuBuilder.php | |
parent | 5dc4e276e18f890b0ae03c472db8cc660fe5c13d (diff) | |
parent | 86acb5cca828931505593c97d969ac60c2bc084f (diff) | |
download | elgg-bdb6d69bc9d81b3cef39bc1b60df731ee81844d3.tar.gz elgg-bdb6d69bc9d81b3cef39bc1b60df731ee81844d3.tar.bz2 |
Merge pull request #293 from Srokap/ticket_3035
Fixes #3035 - menu items appearing in reverse registration order
Diffstat (limited to 'engine/classes/ElggMenuBuilder.php')
-rw-r--r-- | engine/classes/ElggMenuBuilder.php | 32 |
1 files changed, 23 insertions, 9 deletions
diff --git a/engine/classes/ElggMenuBuilder.php b/engine/classes/ElggMenuBuilder.php index de0017599..df0f9147f 100644 --- a/engine/classes/ElggMenuBuilder.php +++ b/engine/classes/ElggMenuBuilder.php @@ -204,6 +204,9 @@ class ElggMenuBuilder { // sort each section foreach ($this->menu as $index => $section) { + foreach ($section as $key => $node) { + $section[$key]->original_order = $key; + } usort($section, $sort_callback); $this->menu[$index] = $section; @@ -232,10 +235,14 @@ class ElggMenuBuilder { * @return bool */ public static function compareByText($a, $b) { - $a = $a->getText(); - $b = $b->getText(); + $at = $a->getText(); + $bt = $b->getText(); - return strnatcmp($a, $b); + $result = strnatcmp($at, $bt); + if ($result === 0) { + return $a->original_order - $b->original_order; + } + return $result; } /** @@ -246,10 +253,14 @@ class ElggMenuBuilder { * @return bool */ public static function compareByName($a, $b) { - $a = $a->getName(); - $b = $b->getName(); + $an = $a->getName(); + $bn = $b->getName(); - return strcmp($a, $b); + $result = strcmp($an, $bn); + if ($result === 0) { + return $a->original_order - $b->original_order; + } + return $result; } /** @@ -260,9 +271,12 @@ class ElggMenuBuilder { * @return bool */ public static function compareByWeight($a, $b) { - $a = $a->getWeight(); - $b = $b->getWeight(); + $aw = $a->getWeight(); + $bw = $b->getWeight(); - return $a > $b; + if ($aw == $bw) { + return $a->original_order - $b->original_order; + } + return $aw - $bw; } } |