Commit f5f3d2e4 by Qiang Xue

Added bootstrap. form WIP

parent 69b2b372
This source diff could not be displayed because it is too large. You can view the blob instead.
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -7,17 +7,20 @@ use yii\helpers\Html; ...@@ -7,17 +7,20 @@ use yii\helpers\Html;
?> ?>
<?php $this->beginPage(); ?> <?php $this->beginPage(); ?>
<!DOCTYPE html> <!DOCTYPE html>
<html> <html lang="en">
<head> <head>
<meta charset="utf-8" /> <meta charset="utf-8" />
<title><?php echo Html::encode($this->title); ?></title> <title><?php echo Html::encode($this->title); ?></title>
<?php echo Html::cssFile("css/bootstrap.min.css", array('media' => 'screen')); ?>
<?php $this->head(); ?> <?php $this->head(); ?>
</head> </head>
<body> <body>
<h1>Welcome</h1> <div class="container">
<?php $this->beginBody(); ?> <h1>Welcome</h1>
<?php echo $content; ?> <?php $this->beginBody(); ?>
<?php $this->endBody(); ?> <?php echo $content; ?>
<?php $this->endBody(); ?>
</div>
</body> </body>
</html> </html>
<?php $this->endPage(); ?> <?php $this->endPage(); ?>
\ No newline at end of file
<?php <?php
use yii\helpers\Html; use yii\helpers\Html;
/** /**
* @var yii\base\View $this * @var yii\base\View $this
* @var yii\widgets\ActiveForm $form * @var yii\widgets\ActiveForm $form
...@@ -11,9 +10,13 @@ use yii\helpers\Html; ...@@ -11,9 +10,13 @@ use yii\helpers\Html;
<p>Please fill out the following fields to login:</p> <p>Please fill out the following fields to login:</p>
<?php $form = $this->beginWidget('yii\widgets\ActiveForm'); ?> <?php $form = $this->beginWidget('yii\widgets\ActiveForm', array('options' => array('class' => 'form-horizontal'))); ?>
<?php echo $form->field($model, 'username')->textInput(); ?> <?php echo $form->field($model, 'username')->textInput(); ?>
<?php echo $form->field($model, 'password')->passwordInput(); ?> <?php echo $form->field($model, 'password')->passwordInput(); ?>
<?php echo $form->field($model, 'rememberMe')->checkbox(); ?> <?php echo $form->field($model, 'rememberMe')->checkbox(); ?>
<?php echo Html::submitButton('Login'); ?> <div class="control-group">
<div class="controls">
<?php echo Html::submitButton('Login', null, null, array('class' => 'btn btn-primary')); ?>
</div>
</div>
<?php $this->endWidget(); ?> <?php $this->endWidget(); ?>
\ No newline at end of file
...@@ -1331,7 +1331,9 @@ class Html ...@@ -1331,7 +1331,9 @@ class Html
* If the input parameter * If the input parameter
* *
* - is an empty string: the currently requested URL will be returned; * - is an empty string: the currently requested URL will be returned;
* - is a non-empty string: it will be processed by [[Yii::getAlias()]] and returned; * - is a non-empty string: it will first be processed by [[Yii::getAlias()]]. If the result
* is an absolute URL, it will be returned with any change further; Otherwise, the result
* will be prefixed with [[\yii\web\Request::baseUrl]] and returned.
* - is an array: the first array element is considered a route, while the rest of the name-value * - is an array: the first array element is considered a route, while the rest of the name-value
* pairs are treated as the parameters to be used for URL creation using [[\yii\web\Controller::createUrl()]]. * pairs are treated as the parameters to be used for URL creation using [[\yii\web\Controller::createUrl()]].
* For example: `array('post/index', 'page' => 2)`, `array('index')`. * For example: `array('post/index', 'page' => 2)`, `array('index')`.
...@@ -1357,7 +1359,12 @@ class Html ...@@ -1357,7 +1359,12 @@ class Html
} elseif ($url === '') { } elseif ($url === '') {
return Yii::$app->getRequest()->getUrl(); return Yii::$app->getRequest()->getUrl();
} else { } else {
return Yii::getAlias($url); $url = Yii::getAlias($url);
if ($url[0] === '/' || strpos($url, '://')) {
return $url;
} else {
return Yii::$app->getRequest()->getBaseUrl() . '/' . $url;
}
} }
} }
......
...@@ -9,6 +9,7 @@ namespace yii\widgets; ...@@ -9,6 +9,7 @@ namespace yii\widgets;
use yii\base\Component; use yii\base\Component;
use yii\helpers\Html; use yii\helpers\Html;
use yii\base\Model;
/** /**
* @author Qiang Xue <qiang.xue@gmail.com> * @author Qiang Xue <qiang.xue@gmail.com>
...@@ -17,15 +18,15 @@ use yii\helpers\Html; ...@@ -17,15 +18,15 @@ use yii\helpers\Html;
class ActiveField extends Component class ActiveField extends Component
{ {
/** /**
* @var ActiveForm * @var ActiveForm the form that this field is associated with.
*/ */
public $form; public $form;
/** /**
* @var \yii\base\Model * @var Model the data model that this field is associated with
*/ */
public $model; public $model;
/** /**
* @var string * @var string the model attribute that this field is associated with
*/ */
public $attribute; public $attribute;
/** /**
...@@ -33,42 +34,40 @@ class ActiveField extends Component ...@@ -33,42 +34,40 @@ class ActiveField extends Component
*/ */
public $tag = 'div'; public $tag = 'div';
/** /**
* @var array * @var array the HTML attributes (name-value pairs) for the field container tag.
* The values will be HTML-encoded using [[Html::encode()]].
* If a value is null, the corresponding attribute will not be rendered.
*/ */
public $options = array( public $options = array(
'class' => 'yii-field', 'class' => 'control-group',
); );
/** /**
* @var string the default CSS class that indicates an input is required. * @var string the template that is used to arrange the label, the input and the error message.
* The following tokens will be replaced when [[render()]] is called: `{label}`, `{input}` and `{error}`.
*/ */
public $requiredCssClass = 'required'; public $template = "{label}\n<div class=\"controls\">\n{input}\n{error}\n</div>";
/** /**
* @var string the default CSS class that indicates an input has error. * @var array the default options for the error message. This property is used when calling [[error()]]
* without the `$options` parameter.
*/ */
public $errorCssClass = 'error'; public $errorOptions = array('tag' => 'span', 'class' => 'help-inline');
/** /**
* @var string the default CSS class that indicates an input validated successfully. * @var array the default options for the label. This property is used when calling [[label()]]
* without the `$options` parameter.
*/ */
public $successCssClass = 'success';
/**
* @var string the default CSS class that indicates an input is currently being validated.
*/
public $validatingCssClass = 'validating';
public $template = "{label}\n{input}\n{error}";
public $errorOptions = array('tag' => 'span', 'class' => 'yii-error-message');
public $labelOptions = array('class' => 'control-label'); public $labelOptions = array('class' => 'control-label');
public function begin() public function begin()
{ {
$options = $this->options; $options = $this->options;
$class = isset($options['class']) ? array($options['class']) : array(); $class = isset($options['class']) ? array($options['class']) : array();
$class[] = 'field-' . Html::getInputId($this->model, $this->attribute); $class[] = 'field-' . Html::getInputId($this->model, $this->attribute);
if ($this->model->isAttributeRequired($this->attribute)) { if ($this->model->isAttributeRequired($this->attribute)) {
$class[] = $this->requiredCssClass; $class[] = $this->form->requiredCssClass;
} }
if ($this->model->hasErrors($this->attribute)) { if ($this->model->hasErrors($this->attribute)) {
$class[] = $this->errorCssClass; $class[] = $this->form->errorCssClass;
} }
$options['class'] = implode(' ', $class); $options['class'] = implode(' ', $class);
return Html::beginTag($this->tag, $options); return Html::beginTag($this->tag, $options);
...@@ -235,27 +234,11 @@ class ActiveField extends Component ...@@ -235,27 +234,11 @@ class ActiveField extends Component
* *
* The rest of the options will be rendered as the attributes of the resulting tag. The values will * The rest of the options will be rendered as the attributes of the resulting tag. The values will
* be HTML-encoded using [[encode()]]. If a value is null, the corresponding attribute will not be rendered. * be HTML-encoded using [[encode()]]. If a value is null, the corresponding attribute will not be rendered.
* @param boolean $enclosedByLabel whether to enclose the radio button within the label tag.
* If this is true, [[template]] will be ignored.
* @return string the generated radio button tag * @return string the generated radio button tag
*/ */
public function radio($options = array(), $enclosedByLabel = true) public function radio($options = array())
{ {
if ($enclosedByLabel) { return $this->render(Html::activeRadio($this->model, $this->attribute, $options));
$name = isset($options['name']) ? $options['name'] : Html::getInputName($this->model, $this->attribute);
$checked = Html::getAttributeValue($this->model, $this->attribute);
$radio = Html::radio($name, $checked, $options);
$uncheck = array_key_exists('unchecked', $options) ? $options['uncheck'] : '0';
unset($options['uncheck']);
$hidden = $uncheck !== null ? Html::hiddenInput($name, $uncheck) : '';
$label = Html::encode($this->model->getAttributeLabel($this->attribute));
return $this->begin() . "\n"
. $hidden . Html::label("$radio $label", null, $this->labelOptions) . "\n"
. $this->error() . "\n"
. $this->end();
} else {
return Html::activeRadio($this->model, $this->attribute, $options);
}
} }
/** /**
...@@ -271,27 +254,11 @@ class ActiveField extends Component ...@@ -271,27 +254,11 @@ class ActiveField extends Component
* *
* The rest of the options will be rendered as the attributes of the resulting tag. The values will * The rest of the options will be rendered as the attributes of the resulting tag. The values will
* be HTML-encoded using [[encode()]]. If a value is null, the corresponding attribute will not be rendered. * be HTML-encoded using [[encode()]]. If a value is null, the corresponding attribute will not be rendered.
* @param boolean $enclosedByLabel whether to enclose the checkbox within the label tag.
* If this is true, [[template]] will be ignored.
* @return string the generated checkbox tag * @return string the generated checkbox tag
*/ */
public function checkbox($options = array(), $enclosedByLabel = true) public function checkbox($options = array())
{ {
if ($enclosedByLabel) { return $this->render(Html::activeCheckbox($this->model, $this->attribute, $options));
$name = isset($options['name']) ? $options['name'] : Html::getInputName($this->model, $this->attribute);
$checked = Html::getAttributeValue($this->model, $this->attribute);
$checkbox = Html::checkbox($name, $checked, $options);
$uncheck = array_key_exists('unchecked', $options) ? $options['uncheck'] : '0';
unset($options['uncheck']);
$hidden = $uncheck !== null ? Html::hiddenInput($name, $uncheck) : '';
$label = Html::encode($this->model->getAttributeLabel($this->attribute));
return $this->begin() . "\n"
. $hidden . Html::label("$checkbox $label", null, $this->labelOptions) . "\n"
. $this->error() . "\n"
. $this->end();
} else {
return Html::activeCheckbox($this->model, $this->attribute, $options);
}
} }
/** /**
......
...@@ -11,7 +11,6 @@ use Yii; ...@@ -11,7 +11,6 @@ use Yii;
use yii\base\Widget; use yii\base\Widget;
use yii\base\Model; use yii\base\Model;
use yii\helpers\Html; use yii\helpers\Html;
use yii\helpers\ArrayHelper;
/** /**
* ActiveForm ... * ActiveForm ...
...@@ -31,8 +30,8 @@ class ActiveForm extends Widget ...@@ -31,8 +30,8 @@ class ActiveForm extends Widget
*/ */
public $method = 'post'; public $method = 'post';
/** /**
* @param array $options the attributes (name-value pairs) for the form tag. * @var array the HTML attributes (name-value pairs) for the form tag.
* The values will be HTML-encoded using [[encode()]]. * The values will be HTML-encoded using [[Html::encode()]].
* If a value is null, the corresponding attribute will not be rendered. * If a value is null, the corresponding attribute will not be rendered.
*/ */
public $options = array(); public $options = array();
...@@ -53,6 +52,22 @@ class ActiveForm extends Widget ...@@ -53,6 +52,22 @@ class ActiveForm extends Widget
public $fieldConfig = array( public $fieldConfig = array(
'class' => 'yii\widgets\ActiveField', 'class' => 'yii\widgets\ActiveField',
); );
/**
* @var string the CSS class that is added to a field container when the associated attribute is required.
*/
public $requiredCssClass = 'required';
/**
* @var string the CSS class that is added to a field container when the associated attribute has validation error.
*/
public $errorCssClass = 'error';
/**
* @var string the CSS class that is added to a field container when the associated attribute is successfully validated.
*/
public $successCssClass = 'success';
/**
* @var string the CSS class that is added to a field container when the associated attribute is being validated.
*/
public $validatingCssClass = 'validating';
/** /**
* Initializes the widget. * Initializes the widget.
...@@ -73,9 +88,17 @@ class ActiveForm extends Widget ...@@ -73,9 +88,17 @@ class ActiveForm extends Widget
} }
/** /**
* @param Model|Model[] $models * Generates a summary of the validation errors.
* @param array $options * If there is no validation error, an empty error summary markup will still be generated, but it will be hidden.
* @return string * @param Model|Model[] $models the model(s) associated with this form
* @param array $options the tag options in terms of name-value pairs. The following options are specially handled:
*
* - header: string, the header HTML for the error summary. If not set, a default prompt string will be used.
* - footer: string, the footer HTML for the error summary.
*
* The rest of the options will be rendered as the attributes of the container tag. The values will
* be HTML-encoded using [[encode()]]. If a value is null, the corresponding attribute will not be rendered.
* @return string the generated error summary
*/ */
public function errorSummary($models, $options = array()) public function errorSummary($models, $options = array())
{ {
...@@ -83,23 +106,17 @@ class ActiveForm extends Widget ...@@ -83,23 +106,17 @@ class ActiveForm extends Widget
$models = array($models); $models = array($models);
} }
$showAll = !empty($options['showAll']);
$lines = array(); $lines = array();
/** @var $model Model */
foreach ($models as $model) { foreach ($models as $model) {
if ($showAll) { /** @var $model Model */
foreach ($model->getErrors() as $errors) { foreach ($model->getFirstErrors() as $error) {
$lines = array_merge($lines, $errors); $lines[] = Html::encode($error);
}
} else {
$lines = array_merge($lines, $model->getFirstErrors());
} }
} }
$header = isset($options['header']) ? $options['header'] : '<p>' . Yii::t('yii|Please fix the following errors:') . '</p>'; $header = isset($options['header']) ? $options['header'] : '<p>' . Yii::t('yii|Please fix the following errors:') . '</p>';
$footer = isset($options['footer']) ? $options['footer'] : ''; $footer = isset($options['footer']) ? $options['footer'] : '';
$tag = isset($options['tag']) ? $options['tag'] : 'div'; unset($options['header'], $options['footer']);
unset($options['showAll'], $options['header'], $options['footer'], $options['container']);
if (!isset($options['class'])) { if (!isset($options['class'])) {
$options['class'] = $this->errorSummaryCssClass; $options['class'] = $this->errorSummaryCssClass;
...@@ -108,22 +125,30 @@ class ActiveForm extends Widget ...@@ -108,22 +125,30 @@ class ActiveForm extends Widget
} }
if ($lines !== array()) { if ($lines !== array()) {
$content = "<ul><li>" . implode("</li>\n<li>", ArrayHelper::htmlEncode($lines)) . "</li><ul>"; $content = "<ul><li>" . implode("</li>\n<li>", $lines) . "</li><ul>";
return Html::tag($tag, $header . $content . $footer, $options); return Html::tag('div', $header . $content . $footer, $options);
} else { } else {
$content = "<ul></ul>"; $content = "<ul></ul>";
$options['style'] = isset($options['style']) ? rtrim($options['style'], ';') . '; display:none' : 'display:none'; $options['style'] = isset($options['style']) ? rtrim($options['style'], ';') . '; display:none' : 'display:none';
return Html::tag($tag, $header . $content . $footer, $options); return Html::tag('div', $header . $content . $footer, $options);
} }
} }
public function field($model, $attribute, $options = null) /**
* Generates a form field.
* A form field is associated with a model and an attribute. It contains a label, an input and an error message
* and use them to interact with end users to collect their inputs for the attribute.
* @param Model $model the data model
* @param string $attribute the attribute name or expression. See [[Html::getAttributeName()]] for the format
* about attribute expression.
* @return ActiveField the created ActiveField object
*/
public function field($model, $attribute, $options = array())
{ {
return Yii::createObject(array_merge($this->fieldConfig, array( return Yii::createObject(array_merge($this->fieldConfig, $options, array(
'model' => $model, 'model' => $model,
'attribute' => $attribute, 'attribute' => $attribute,
'form' => $this, 'form' => $this,
'options' => $options,
))); )));
} }
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment