You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							116 lines
						
					
					
						
							3.0 KiB
						
					
					
				
			
		
		
	
	
							116 lines
						
					
					
						
							3.0 KiB
						
					
					
				<?php | 
						|
/** | 
						|
 * @link http://www.yiiframework.com/ | 
						|
 * @copyright Copyright (c) 2008 Yii Software LLC | 
						|
 * @license http://www.yiiframework.com/license/ | 
						|
 */ | 
						|
 | 
						|
namespace yii\jui; | 
						|
 | 
						|
use yii\base\InvalidConfigException; | 
						|
use yii\helpers\ArrayHelper; | 
						|
use yii\helpers\Html; | 
						|
 | 
						|
/** | 
						|
 * Sortable renders a sortable jQuery UI widget. | 
						|
 * | 
						|
 * For example: | 
						|
 * | 
						|
 * ```php | 
						|
 * echo Sortable::widget(array( | 
						|
 *     'items' => array( | 
						|
 *         'Item 1', | 
						|
 *         array( | 
						|
 *             'content' => 'Item2', | 
						|
 *         ), | 
						|
 *         array( | 
						|
 *             'content' => 'Item3', | 
						|
 *             'options' => array( | 
						|
 *                 'tag' => 'li', | 
						|
 *             ), | 
						|
 *         ), | 
						|
 *     ), | 
						|
 *     'options' => array( | 
						|
 *         'tag' => 'ul', | 
						|
 *     ), | 
						|
 *     'itemOptions' => array( | 
						|
 *         'tag' => 'li', | 
						|
 *     ), | 
						|
 *     'clientOptions' => array( | 
						|
 *         'cursor' => 'move', | 
						|
 *     ), | 
						|
 * )); | 
						|
 * ``` | 
						|
 * | 
						|
 * @see http://api.jqueryui.com/sortable/ | 
						|
 * @author Alexander Kochetov <creocoder@gmail.com> | 
						|
 * @since 2.0 | 
						|
 */ | 
						|
class Sortable extends Widget | 
						|
{ | 
						|
	/** | 
						|
	 * @var array the HTML attributes for the widget container tag. The following special options are recognized: | 
						|
	 * | 
						|
	 * - tag: string, defaults to "ul", the tag name of the container tag of this widget | 
						|
	 */ | 
						|
	public $options = array(); | 
						|
	/** | 
						|
	 * @var array list of sortable items. Each item can be a string representing the item content | 
						|
	 * or an array of the following structure: | 
						|
	 * | 
						|
	 * ~~~ | 
						|
	 * array( | 
						|
	 *     'content' => 'item content', | 
						|
	 *     // the HTML attributes of the item container tag. This will overwrite "itemOptions". | 
						|
	 *     'options' => array(), | 
						|
	 * ) | 
						|
	 * ~~~ | 
						|
	 */ | 
						|
	public $items = array(); | 
						|
	/** | 
						|
	 * @var array list of HTML attributes for the item container tags. This will be overwritten | 
						|
	 * by the "options" set in individual [[items]]. The following special options are recognized: | 
						|
	 * | 
						|
	 * - tag: string, defaults to "li", the tag name of the item container tags. | 
						|
	 */ | 
						|
	public $itemOptions = array(); | 
						|
 | 
						|
 | 
						|
	/** | 
						|
	 * Renders the widget. | 
						|
	 */ | 
						|
	public function run() | 
						|
	{ | 
						|
		$options = $this->options; | 
						|
		$tag = ArrayHelper::remove($options, 'tag', 'ul'); | 
						|
		echo Html::beginTag($tag, $options) . "\n"; | 
						|
		echo $this->renderItems() . "\n"; | 
						|
		echo Html::endTag($tag) . "\n"; | 
						|
		$this->registerWidget('sortable', false); | 
						|
	} | 
						|
 | 
						|
	/** | 
						|
	 * Renders sortable items as specified on [[items]]. | 
						|
	 * @return string the rendering result. | 
						|
	 * @throws InvalidConfigException. | 
						|
	 */ | 
						|
	public function renderItems() | 
						|
	{ | 
						|
		$items = array(); | 
						|
		foreach ($this->items as $item) { | 
						|
			$options = $this->itemOptions; | 
						|
			$tag = ArrayHelper::remove($options, 'tag', 'li'); | 
						|
			if (is_array($item)) { | 
						|
				if (!isset($item['content'])) { | 
						|
					throw new InvalidConfigException("The 'content' option is required."); | 
						|
				} | 
						|
				$options = array_merge($options, ArrayHelper::getValue($item, 'options', array())); | 
						|
				$tag = ArrayHelper::remove($options, 'tag', $tag); | 
						|
				$items[] = Html::tag($tag, $item['content'], $options); | 
						|
			} else { | 
						|
				$items[] = Html::tag($tag, $item, $options); | 
						|
			} | 
						|
		} | 
						|
		return implode("\n", $items); | 
						|
	} | 
						|
}
 | 
						|
 |