Commit ae09e5e9 authored by Taylor Otwell's avatar Taylor Otwell

extract id assignment to method.

parent 7f3baf97
......@@ -19,9 +19,6 @@ class Form {
*/
public static function open($action = null, $method = 'POST', $attributes = array())
{
// -------------------------------------------------------
// If no action was given, use the current URI.
// -------------------------------------------------------
if (is_null($action))
{
$action = Request::uri();
......@@ -80,6 +77,10 @@ class Form {
*/
public static function raw_token()
{
// -------------------------------------------------------
// CSRF tokens are stored in the session, so we need to
// make sure a driver has been specified.
// -------------------------------------------------------
if (Config::get('session.driver') == '')
{
throw new \Exception('Sessions must be enabled to retrieve a CSRF token.');
......@@ -221,8 +222,8 @@ class Form {
{
$attributes['checked'] = 'checked';
}
(in_array($name, static::$labels)) ? $attributes['id'] = $name : null;
$attributes['id'] = static::id($name, $attributes);
return static::input($type, $name, $value, $attributes);
}
......@@ -238,7 +239,7 @@ class Form {
public static function textarea($name, $value = '', $attributes = array())
{
$attributes['name'] = $name;
(in_array($name, static::$labels)) ? $attributes['id'] = $name : null;
$attributes['id'] = static::id($name, $attributes);
// -------------------------------------------------------
// Set the default number of rows.
......@@ -271,7 +272,7 @@ class Form {
public static function select($name, $options = array(), $selected = null, $attributes = array())
{
$attributes['name'] = $name;
(in_array($name, static::$labels)) ? $attributes['id'] = $name : null;
$attributes['id'] = static::id($name, $attributes);
$html_options = array();
......@@ -301,9 +302,37 @@ class Form {
$attributes['type'] = $type;
$attributes['name'] = $name;
$attributes['value'] = $value;
(in_array($name, static::$labels)) ? $attributes['id'] = $name : null;
$attributes['id'] = static::id($name, $attributes);
return '<input'.HTML::attributes($attributes).' />'.PHP_EOL;
}
/**
* Determine the ID attribute for a form element.
*
* @param string $name
* @param array $attributes
* @return mixed
*/
private static function id($name, $attributes)
{
// -------------------------------------------------------
// If an ID attribute was already explicitly specified
// for the element, just use that.
// -------------------------------------------------------
if (array_key_exists('id', $attributes))
{
return $attributes['id'];
}
// -------------------------------------------------------
// If a label element was created with a value matching
// the name of the form element, use the name as the ID.
// -------------------------------------------------------
if (in_array($name, static::$labels))
{
return $name;
}
}
}
\ No newline at end of file
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