|  |  |  | <?php
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @link http://www.yiiframework.com/
 | 
					
						
							|  |  |  |  * @copyright Copyright (c) 2008 Yii Software LLC
 | 
					
						
							|  |  |  |  * @license http://www.yiiframework.com/license/
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace yii\bootstrap;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Yii;
 | 
					
						
							|  |  |  | use yii\helpers\Json;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * \yii\bootstrap\Widget is the base class for all bootstrap widgets.
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * @author Antonio Ramirez <amigo.cobos@gmail.com>
 | 
					
						
							|  |  |  |  * @author Qiang Xue <qiang.xue@gmail.com>
 | 
					
						
							|  |  |  |  * @since 2.0
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | class Widget extends \yii\base\Widget
 | 
					
						
							|  |  |  | {
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @var array the HTML attributes for the widget container tag.
 | 
					
						
							|  |  |  |      * @see \yii\helpers\Html::renderTagAttributes() for details on how attributes are being rendered.
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public $options = [];
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @var array the options for the underlying Bootstrap JS plugin.
 | 
					
						
							|  |  |  |      * Please refer to the corresponding Bootstrap plugin Web page for possible options.
 | 
					
						
							|  |  |  |      * For example, [this page](http://getbootstrap.com/javascript/#modals) shows
 | 
					
						
							|  |  |  |      * how to use the "Modal" plugin and the supported options (e.g. "remote").
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public $clientOptions = [];
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @var array the event handlers for the underlying Bootstrap JS plugin.
 | 
					
						
							|  |  |  |      * Please refer to the corresponding Bootstrap plugin Web page for possible events.
 | 
					
						
							|  |  |  |      * For example, [this page](http://getbootstrap.com/javascript/#modals) shows
 | 
					
						
							|  |  |  |      * how to use the "Modal" plugin and the supported events (e.g. "shown").
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public $clientEvents = [];
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Initializes the widget.
 | 
					
						
							|  |  |  |      * This method will register the bootstrap asset bundle. If you override this method,
 | 
					
						
							|  |  |  |      * make sure you call the parent implementation first.
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public function init()
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         parent::init();
 | 
					
						
							|  |  |  |         if (!isset($this->options['id'])) {
 | 
					
						
							|  |  |  |             $this->options['id'] = $this->getId();
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Registers a specific Bootstrap plugin and the related events
 | 
					
						
							|  |  |  |      * @param string $name the name of the Bootstrap plugin
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     protected function registerPlugin($name)
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         $view = $this->getView();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         BootstrapPluginAsset::register($view);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $id = $this->options['id'];
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($this->clientOptions !== false) {
 | 
					
						
							|  |  |  |             $options = empty($this->clientOptions) ? '' : Json::encode($this->clientOptions);
 | 
					
						
							|  |  |  |             $js = "jQuery('#$id').$name($options);";
 | 
					
						
							|  |  |  |             $view->registerJs($js);
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($this->clientEvents)) {
 | 
					
						
							|  |  |  |             $js = [];
 | 
					
						
							|  |  |  |             foreach ($this->clientEvents as $event => $handler) {
 | 
					
						
							|  |  |  |                 $js[] = "jQuery('#$id').on('$event', $handler);";
 | 
					
						
							|  |  |  |             }
 | 
					
						
							|  |  |  |             $view->registerJs(implode("\n", $js));
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 |