X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fmoremenu.php;h=3562ac41485bd77338b269bd23f48ec6db894205;hb=b53e1439969bfa2c0b551d8cc2fc8fe15652c62a;hp=e8c16b0d6e25a28e7524941cd48054251be3537b;hpb=1c917ac28f4a1e4c58aed600c5b4c8bef4645cb5;p=quix0rs-gnu-social.git diff --git a/lib/moremenu.php b/lib/moremenu.php index e8c16b0d6e..3562ac4148 100644 --- a/lib/moremenu.php +++ b/lib/moremenu.php @@ -4,7 +4,7 @@ * Copyright (C) 2011, StatusNet, Inc. * * A menu with a More... button to show more elements - * + * * PHP version 5 * * This program is free software: you can redistribute it and/or modify @@ -44,12 +44,11 @@ if (!defined('STATUSNET')) { * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 * @link http://status.net/ */ - class MoreMenu extends Menu { const SOFT_MAX = 5; const HARD_MAX = 15; - + /** * Show a menu with a limited number of elements * @@ -57,20 +56,20 @@ class MoreMenu extends Menu * * @return */ - function show() { $items = $this->getItems(); $tag = $this->tag(); + $menuID = null; $attrs = array('class' => 'nav'); if (!is_null($tag)) { - $attrs['id'] = 'nav_' . $tag; + $menuID = 'nav_' . $tag; + $attrs['id'] = $menuID; } if (Event::handle('StartNav', array($this, &$tag, &$items))) { - $this->out->elementStart('ul', $attrs); $total = count($items); @@ -82,31 +81,50 @@ class MoreMenu extends Menu } foreach ($toShow as $item) { - list($actionName, $args, $label, $description, $id) = $item; + if (count($item) == 5) { + list($actionName, $args, $label, $description, $id) = $item; + } else { + list($actionName, $args, $label, $description) = $item; + $id = null; + } $this->item($actionName, $args, $label, $description, $id); } if ($total > self::SOFT_MAX + 1) { - $this->out->elementStart('li'); - $this->out->element('a', array('href' => '#'), + $this->out->elementStart('li', array('class' => 'more_link')); + $this->out->element('a', array('href' => '#', + 'onclick' => 'SN.U.showMoreMenuItems("'.$menuID.'"); return false;'), + // TRANS: Link description to show more items in a list. _('More ▼')); $this->out->elementEnd('li'); $extended = array_slice($items, self::SOFT_MAX, self::HARD_MAX - self::SOFT_MAX); foreach ($extended as $item) { - list($actionName, $args, $label, $description, $id) = $item; + if (count($item) == 5) { + list($actionName, $args, $label, $description, $id) = $item; + } else { + list($actionName, $args, $label, $description) = $item; + $id = null; + } $this->item($actionName, $args, $label, $description, $id, 'extended_menu'); } - $seeAll = $this->seeAllItem(); - - if (!empty($seeAll)) { - list($actionName, $args, $label, $description, $id) = $seeAll; - $this->item($actionName, $args, $label, $description, $id, 'extended_menu see_all'); + if ($total > self::HARD_MAX) { + $seeAll = $this->seeAllItem(); + + if (!empty($seeAll)) { + if (count($seeAll) == 5) { + list($actionName, $args, $label, $description, $id) = $seeAll; + } else { + list($actionName, $args, $label, $description) = $seeAll; + $id = null; + } + $this->item($actionName, $args, $label, $description, $id, 'extended_menu see_all'); + } } } - + $this->out->elementEnd('ul'); Event::handle('EndNav', array($this, $tag, $items)); @@ -117,5 +135,4 @@ class MoreMenu extends Menu { return null; } - }