<?php /** * @link http://www.yiiframework.com/ * @copyright Copyright (c) 2008 Yii Software LLC * @license http://www.yiiframework.com/license/ */ namespace yii\jui; use Yii; use yii\helpers\Html; use yii\helpers\Json; /** * DatePicker renders a datepicker jQuery UI widget. * * For example: * * ```php * echo DatePicker::widget([ * 'language' => 'ru', * 'model' => $model, * 'attribute' => 'from_date', * 'clientOptions' => [ * 'dateFormat' => 'yy-mm-dd', * ], * ]); * ``` * * The following example will use the name property instead: * * ```php * echo DatePicker::widget([ * 'language' => 'ru', * 'name' => 'from_date', * 'clientOptions' => [ * 'dateFormat' => 'yy-mm-dd', * ], * ]); * ``` * * @see http://api.jqueryui.com/datepicker/ * @author Alexander Kochetov <creocoder@gmail.com> * @since 2.0 */ class DatePicker extends InputWidget { /** * @var string the locale ID (eg 'fr', 'de') for the language to be used by the date picker. * If this property is empty, then the current application language will be used. */ public $language; /** * @var boolean If true, shows the widget as an inline calendar and the input as a hidden field. */ public $inline = false; /** * @var array the HTML attributes for the container tag. This is only used when [[inline]] is true. * @see \yii\helpers\Html::renderTagAttributes() for details on how attributes are being rendered. */ public $containerOptions = []; /** * @inheritdoc */ public function init() { parent::init(); if ($this->inline && !isset($this->containerOptions['id'])) { $this->containerOptions['id'] = $this->options['id'] . '-container'; } } /** * Renders the widget. */ public function run() { echo $this->renderWidget() . "\n"; $containerID = $this->inline ? $this->containerOptions['id'] : $this->options['id']; $language = $this->language ? $this->language : Yii::$app->language; if ($language != 'en-US') { $view = $this->getView(); DatePickerRegionalAsset::register($view); $options = Json::encode($this->clientOptions); $view->registerJs("$('#{$containerID}').datepicker($.extend({}, $.datepicker.regional['{$language}'], $options));"); $options = $this->clientOptions; $this->clientOptions = false; // the datepicker js widget is already registered $this->registerWidget('datepicker', DatePickerAsset::className(), $containerID); $this->clientOptions = $options; } else { $this->registerWidget('datepicker', DatePickerAsset::className(), $containerID); } } /** * Renders the DatePicker widget. * @return string the rendering result. */ protected function renderWidget() { $contents = []; if ($this->inline === false) { if ($this->hasModel()) { $contents[] = Html::activeTextInput($this->model, $this->attribute, $this->options); } else { $contents[] = Html::textInput($this->name, $this->value, $this->options); } } else { if ($this->hasModel()) { $contents[] = Html::activeHiddenInput($this->model, $this->attribute, $this->options); $this->clientOptions['defaultDate'] = $this->model->{$this->attribute}; } else { $contents[] = Html::hiddenInput($this->name, $this->value, $this->options); $this->clientOptions['defaultDate'] = $this->value; } $this->clientOptions['altField'] = '#' . $this->options['id']; $contents[] = Html::tag('div', null, $this->containerOptions); } return implode("\n", $contents); } }