View file esoTalk-1.0.0g4/core/lib/ETMenu.class.php

File size: 2.18Kb
<?php
// Copyright 2011 Toby Zerner, Simon Zerner
// This file is part of esoTalk. Please see the included license file for usage information.

if (!defined("IN_ESOTALK")) exit;

/**
 * The ETMenu class provides a way to collect menu items and then render them as list items in a menu.
 *
 * @package esoTalk
 */
class ETMenu {


/**
 * A list of menu items.
 * @var array
 */
public $items = array();


/**
 * A list of menu item keys to highlight.
 * @var array
 */
public $highlight = array();


/**
 * Add an item to this menu collection.
 *
 * @param string $id The name of the menu item.
 * @param string $html The HTML content of the menu item.
 * @param mixed $position The position to put the menu item, relative to other menu items.
 * @see addToArrayString
 * @return void
 */
public function add($id, $html, $position = false)
{
	addToArrayString($this->items, $id, $html, $position);
}


/**
 * Remove an item from this menu collection.
 *
 * @param string $id The name of the menu item.
 * @return void
 */
public function remove($id)
{
	unset($this->items[$id]);
}


/**
 * Add a separator item to this menu collection.
 *
 * @param mixed $position The position to put the menu item, relative to other menu items.
 * @see addToArrayString
 * @return void
 */
public function separator($position = false)
{
	addToArrayString($this->items, count($this->items) + 1, "separator", $position);
}


/**
 * Highlight a particular menu item.
 *
 * @param string $id The name of the menu item to highlight.
 * @return void
 */
public function highlight($id)
{
	$this->highlight[] = $id;
}


/**
 * Get the contents of the menu as a string of <li> elements.
 *
 * @return string The HTML contents of the menu.
 */
public function getContents()
{
	$return = "";
	$i = 0;
	$count = count($this->items);
	foreach ($this->items as $k => $v) {
		if ($v == "separator") {
			if ($i != 0 and $i != $count - 1) $return .= "<li class='sep'></li>\n";
		}
		else $return .= "<li class='item-$k".(in_array($k, $this->highlight) ? " selected" : "")."'>$v</li>\n";
		$i++;
	}
	return $return;
}


/**
 * Get the number of menu items collected in this menu.
 *
 * @return int
 */
public function count()
{
	return count($this->items);
}

}