sfJQueryUIPlugin: нет выбора новых записей - PullRequest
0 голосов
/ 21 апреля 2010

Каждый день - новый день с Symfony, но мне это нравится! Сегодня утром я установил sfJQueryUIPlugin. Он имеет очень мало зависимостей и принимает стили themeRoller. Тем не менее, у него есть 2 проблемы:

[Feature_Request] Нет способа указать диапазон года. По умолчанию в поле отображается 20-летний диапазон. например. если значение поля 1993-01-20, диапазон будет от 1983 до 2003. ??? Кто-нибудь нашел выход ???

DatePicker не появляется, когда поле пустое, поэтому оно не отображается при создании новой записи. Чтобы решить эту проблему, я попытался установить значение по умолчанию в поле ввода даты (которое теперь отображается как text), используя $this->setDefault('date_of_birth',date('Y-m-d')); ??? Кто-нибудь сталкивается с этой проблемой выбора теперь доступны при создании новой записи ??? ??? Также это правильный способ установить значение по умолчанию ???

Заранее спасибо.

1 Ответ

0 голосов
/ 22 апреля 2010

Чтобы получить указатель даты в новой регистрационной форме, мне нужно было include javascripts в шаблоне indexSuccess моей формы (моя ошибка)

Что касается года, я изменил файл плагина, добавив в него дополнительный параметр

class sfWidgetFormDateJQueryUI extends sfWidgetForm
{
  protected function configure($options = array(), $attributes = array())
  {

    if(sfContext::hasInstance())
     $this->addOption('culture', sfContext::getInstance()->getUser()->getCulture());
    else
     $this->addOption('culture', "en");
    $this->addOption('change_month',  false);
    $this->addOption('change_year',  false);
    $this->addOption('number_of_months', 1);
    $this->addOption('show_button_panel',  false);
    $this->addOption('theme', '/sfJQueryUIPlugin/css/ui-lightness/jquery-ui.css');
    $this->addOption('year_range', '-30:+0');
    parent::configure($options, $attributes);
  }

  public function render($name, $value = null, $attributes = array(), $errors = array())
  {
    $attributes = $this->getAttributes();

    $input = new sfWidgetFormInput(array(), $attributes);

    $html = $input->render($name, $value);

    $id = $input->generateId($name);
    $culture = $this->getOption('culture');
    $cm = $this->getOption("change_month") ? "true" : "false";
    $cy = $this->getOption("change_year") ? "true" : "false";
    $nom = $this->getOption("number_of_months");
    $sbp = $this->getOption("show_button_panel") ? "true" : "false";
    $yrs = $this->getOption("year_range");

    if ($culture!='en')
    {
    $html .= <<<EOHTML
<script type="text/javascript">
    $(function() {
    var params = $.datepicker.regional['$culture'];
    params.changeMonth = $cm;
    params.changeYear = $cy;
    params.numberOfMonths = $nom;
    params.showButtonPanel = $sbp;
    params.yearRange = "$yrs";
    $("#$id").datepicker(params);
    });
</script>
EOHTML;
    }
    else
    {
    $html .= <<<EOHTML
<script type="text/javascript">
    $(function() {
    var params = {
    changeMonth : $cm,
    changeYear : $cy,
    numberOfMonths : $nom,
    showButtonPanel : $sbp,
    yearRange : "$yrs"
        };
    $("#$id").datepicker(params);
    });
</script>
EOHTML;
    }

    return $html;
  }

  public function getStylesheets()
  {...
  }

  public function getJavaScripts()
  {...
  }

}

и настройте виджет как:

$this->widgetSchema['date_of_birth']= new sfWidgetFormDateJQueryUI(array("change_month" => true, "change_year" => true, "theme" => "smoothness/jquery-ui-1.8.custom.css", "year_range" => "-30:+0"));
...