| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 | 
							- <?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]].
 
-  *
 
-  * For more details and usage information on LinkSorter, see the [guide article on sorting](guide:output-sorting).
 
-  *
 
-  * @author Qiang Xue <qiang.xue@gmail.com>
 
-  * @since 2.0
 
-  */
 
- class LinkSorter extends Widget
 
- {
 
-     /**
 
-      * @var Sort the sort definition
 
-      */
 
-     public $sort;
 
-     /**
 
-      * @var array list of the attributes that support sorting. If not set, it will be determined
 
-      * using [[Sort::attributes]].
 
-      */
 
-     public $attributes;
 
-     /**
 
-      * @var array HTML attributes for the sorter container tag.
 
-      * @see \yii\helpers\Html::ul() for special attributes.
 
-      * @see \yii\helpers\Html::renderTagAttributes() for details on how attributes are being rendered.
 
-      */
 
-     public $options = ['class' => 'sorter'];
 
-     /**
 
-      * @var array HTML attributes for the link in a sorter container tag which are passed to [[Sort::link()]].
 
-      * @see \yii\helpers\Html::renderTagAttributes() for details on how attributes are being rendered.
 
-      * @since 2.0.6
 
-      */
 
-     public $linkOptions = [];
 
-     /**
 
-      * Initializes the sorter.
 
-      */
 
-     public function init()
 
-     {
 
-         parent::init();
 
-         if ($this->sort === null) {
 
-             throw new InvalidConfigException('The "sort" property must be set.');
 
-         }
 
-     }
 
-     /**
 
-      * Executes the widget.
 
-      * This method renders the sort links.
 
-      */
 
-     public function run()
 
-     {
 
-         echo $this->renderSortLinks();
 
-     }
 
-     /**
 
-      * Renders the sort links.
 
-      * @return string the rendering result
 
-      */
 
-     protected function renderSortLinks()
 
-     {
 
-         $attributes = empty($this->attributes) ? array_keys($this->sort->attributes) : $this->attributes;
 
-         $links = [];
 
-         foreach ($attributes as $name) {
 
-             $links[] = $this->sort->link($name, $this->linkOptions);
 
-         }
 
-         return Html::ul($links, array_merge($this->options, ['encode' => false]));
 
-     }
 
- }
 
 
  |