2011-03-02 03:35:20 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* StatusNet, the distributed open-source microblogging tool
|
|
|
|
*
|
|
|
|
* Widget to display an alphabet menu
|
|
|
|
*
|
|
|
|
* PHP version 5
|
|
|
|
*
|
|
|
|
* LICENCE: This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @category Widget
|
|
|
|
* @package StatusNet
|
|
|
|
* @author Zach Copley <zach@status.net>
|
|
|
|
* @copyright 2011 StatusNet, Inc.
|
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
|
|
|
|
* @link http://status.net/
|
|
|
|
*/
|
|
|
|
|
2011-03-04 05:12:24 +00:00
|
|
|
if (!defined('STATUSNET')) {
|
2011-03-02 03:35:20 +00:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Outputs a fancy alphabet letter navigation menu
|
|
|
|
*
|
|
|
|
* @category Widget
|
|
|
|
* @package StatusNet
|
|
|
|
* @author Zach Copley <zach@status.net>
|
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
|
|
|
|
* @link http://status.net/
|
|
|
|
*
|
|
|
|
* @see HTMLOutputter
|
|
|
|
*/
|
|
|
|
|
|
|
|
class AlphaNav extends Widget
|
|
|
|
{
|
|
|
|
protected $action = null;
|
|
|
|
protected $filters = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Prepare the widget for use
|
|
|
|
*
|
|
|
|
* @param Action $action the current action
|
|
|
|
* @param boolean $numbers whether to output 0..9
|
|
|
|
* @param Array $prepend array of filters to prepend
|
|
|
|
* @param Array $append array of filters to append
|
|
|
|
*/
|
|
|
|
function __construct(
|
|
|
|
$action = null,
|
|
|
|
$numbers = false,
|
|
|
|
$prepend = false,
|
|
|
|
$append = false
|
|
|
|
)
|
|
|
|
{
|
|
|
|
parent::__construct($action);
|
|
|
|
|
|
|
|
$this->action = $action;
|
|
|
|
|
|
|
|
if ($prepend) {
|
|
|
|
$this->filters = array_merge($prepend, $this->filters);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($numbers) {
|
|
|
|
$this->filters = array_merge($this->filters, range(0, 9));
|
|
|
|
}
|
|
|
|
|
2011-03-07 22:32:14 +00:00
|
|
|
$this->filters = array_merge($this->filters, range('A', 'Z'));
|
|
|
|
|
2011-03-02 03:35:20 +00:00
|
|
|
if ($append) {
|
|
|
|
$this->filters = array_merge($this->filters, $append);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the widget
|
|
|
|
*
|
|
|
|
* Emit the HTML for the widget, using the configured outputter.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
|
|
|
|
function show()
|
|
|
|
{
|
|
|
|
$actionName = $this->action->trimmed('action');
|
|
|
|
|
2011-03-03 04:21:15 +00:00
|
|
|
$this->action->elementStart('div', array('class' => 'alpha_nav'));
|
|
|
|
|
|
|
|
for ($i = 0, $size = sizeof($this->filters); $i < $size; $i++) {
|
|
|
|
|
|
|
|
$filter = $this->filters[$i];
|
|
|
|
$classes = '';
|
|
|
|
|
|
|
|
// Add some classes for styling
|
|
|
|
if ($i == 0) {
|
|
|
|
$classes .= 'first '; // first filter in the list
|
|
|
|
} elseif ($i == $size - 1) {
|
|
|
|
$classes .= 'last '; // last filter in the list
|
|
|
|
}
|
|
|
|
|
2011-03-02 03:35:20 +00:00
|
|
|
$href = common_local_url(
|
|
|
|
$actionName,
|
2011-03-03 04:21:15 +00:00
|
|
|
array('filter' => strtolower($filter))
|
2011-03-02 03:35:20 +00:00
|
|
|
);
|
2011-03-03 04:21:15 +00:00
|
|
|
|
|
|
|
$params = array('href' => $href);
|
2011-03-04 05:12:24 +00:00
|
|
|
|
|
|
|
// sort column
|
|
|
|
if (!empty($this->action->sort)) {
|
|
|
|
$params['sort'] = $this->action->sort;
|
|
|
|
}
|
|
|
|
|
|
|
|
// sort order
|
2011-03-05 09:55:52 +00:00
|
|
|
if ($this->action->reverse) {
|
|
|
|
$params['reverse'] = 'true';
|
2011-03-04 05:12:24 +00:00
|
|
|
}
|
|
|
|
|
2011-03-03 04:21:15 +00:00
|
|
|
$current = $this->action->arg('filter');
|
|
|
|
|
|
|
|
// Highlight the selected filter. If there is no selected
|
|
|
|
// filter, highlight the first filter in the list
|
2011-03-04 05:12:24 +00:00
|
|
|
if (!isset($current) && $i == 0
|
2011-03-03 04:21:15 +00:00
|
|
|
|| $current === strtolower($filter)) {
|
|
|
|
$classes .= 'current ';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($classes)) {
|
|
|
|
$params['class'] = trim($classes);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->action->element('a', $params, $filter);
|
2011-03-02 03:35:20 +00:00
|
|
|
}
|
2011-03-03 04:21:15 +00:00
|
|
|
|
|
|
|
$this->action->elementEnd('div');
|
2011-03-02 03:35:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|