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.
		
		
		
		
		
			
		
			
				
					
					
						
							78 lines
						
					
					
						
							1.7 KiB
						
					
					
				
			
		
		
	
	
							78 lines
						
					
					
						
							1.7 KiB
						
					
					
				| <?php | |
| /** | |
|  * @link http://www.yiiframework.com/ | |
|  * @copyright Copyright (c) 2008 Yii Software LLC | |
|  * @license http://www.yiiframework.com/license/ | |
|  */ | |
|  | |
| namespace yii\widgets; | |
|  | |
| use Yii; | |
| use yii\base\InvalidConfigException; | |
| use yii\base\Widget; | |
| use yii\data\Sort; | |
| use yii\helpers\Html; | |
|  | |
| /** | |
|  * LinkSorter renders a list of sort links for the given sort definition. | |
|  * | |
|  * LinkSorter will generate a hyperlink for every attribute declared in [[sort]]. | |
|  * | |
|  * @author Qiang Xue <qiang.xue@gmail.com> | |
|  * @since 2.0 | |
|  */ | |
| class LinkSorter extends Widget | |
| { | |
| 	/** | |
| 	 * @var Sort the sort definition | |
| 	 */ | |
| 	public $sort; | |
| 	/** | |
| 	 * @var array HTML attributes for the sorter container tag. | |
| 	 */ | |
| 	public $options = array('class' => 'sorter'); | |
| 	/** | |
| 	 * @var string the template used to render the content within the sorter container. | |
| 	 * The token "{links}" will be replaced with the actual sort links. | |
| 	 */ | |
| 	public $template; | |
|  | |
| 	/** | |
| 	 * Initializes the sorter. | |
| 	 */ | |
| 	public function init() | |
| 	{ | |
| 		if ($this->sort === null) { | |
| 			throw new InvalidConfigException('The "sort" property must be set.'); | |
| 		} | |
|  | |
| 		if ($this->template === null) { | |
| 			$this->template = '<label>' . Yii::t('yii', 'Sort by:') . '</label> {links}'; | |
| 		} | |
| 	} | |
|  | |
| 	/** | |
| 	 * Executes the widget. | |
| 	 * This method renders the sort links. | |
| 	 */ | |
| 	public function run() | |
| 	{ | |
| 		$links = strtr($this->template, array( | |
| 			'{links}' => $this->renderSortLinks(), | |
| 		)); | |
| 		echo Html::tag('div', $links, $this->options); | |
| 	} | |
|  | |
| 	/** | |
| 	 * Renders the sort links. | |
| 	 * @return string the rendering result | |
| 	 */ | |
| 	protected function renderSortLinks() | |
| 	{ | |
| 		$links = array(); | |
| 		foreach (array_keys($this->sort->attributes) as $name) { | |
| 			$links[] = $this->sort->link($name); | |
| 		} | |
| 		return Html::ul($links, array('encode' => false)); | |
| 	} | |
| }
 | |
| 
 |