'."\n"; // Add hidden fields immediate after opening tag empty($hidden) or $form .= form::hidden($hidden); return $form; } /** * Generates an opening HTML form tag that can be used for uploading files. * * @param string form action attribute * @param array extra attributes * @param array hidden fields to be created immediately after the form tag * @return string */ public static function open_multipart($action = NULL, $attr = array(), $hidden = array()) { // Set multi-part form type $attr['enctype'] = 'multipart/form-data'; return form::open($action, $attr, $hidden); } /** * Generates a fieldset opening tag. * * @param array html attributes * @param string a string to be attached to the end of the attributes * @return string */ public static function open_fieldset($data = NULL, $extra = '') { return '
'."\n"; } /** * Generates a legend tag for use with a fieldset. * * @param string legend text * @param array HTML attributes * @param string a string to be attached to the end of the attributes * @return string */ public static function legend($text = '', $data = NULL, $extra = '') { return ''."\n"; } /** * Generates hidden form fields. * You can pass a simple key/value string or an associative array with multiple values. * * @param string|array input name (string) or key/value pairs (array) * @param string input value, if using an input name * @return string */ public static function hidden($data, $value = '') { if ( ! is_array($data)) { $data = array ( $data => $value ); } $input = ''; foreach ($data as $name => $value) { $attr = array ( 'type' => 'hidden', 'name' => $name, 'value' => $value ); $input .= form::input($attr)."\n"; } return $input; } /** * Creates an HTML form input tag. Defaults to a text type. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param string a string to be attached to the end of the attributes * @return string */ public static function input($data, $value = '', $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } // Type and value are required attributes $data += array ( 'type' => 'text', 'value' => $value ); return ''; } /** * Creates a HTML form password input tag. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param string a string to be attached to the end of the attributes * @return string */ public static function password($data, $value = '', $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } $data['type'] = 'password'; return form::input($data, $value, $extra); } /** * Creates an HTML form upload input tag. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param string a string to be attached to the end of the attributes * @return string */ public static function upload($data, $value = '', $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } $data['type'] = 'file'; return form::input($data, $value, $extra); } /** * Creates an HTML form textarea tag. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param string a string to be attached to the end of the attributes * @param boolean encode existing entities * @return string */ public static function textarea($data, $value = '', $extra = '', $double_encode = TRUE) { if ( ! is_array($data)) { $data = array('name' => $data); } // Use the value from $data if possible, or use $value $value = isset($data['value']) ? $data['value'] : $value; // Value is not part of the attributes unset($data['value']); return ''; } /** * Creates an HTML form select tag, or "dropdown menu". * * @param string|array input name or an array of HTML attributes * @param array select options, when using a name * @param string|array option key(s) that should be selected by default * @param string a string to be attached to the end of the attributes * @return string */ public static function dropdown($data, $options = NULL, $selected = NULL, $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } else { if (isset($data['options'])) { // Use data options $options = $data['options']; } if (isset($data['selected'])) { // Use data selected $selected = $data['selected']; } } if (is_array($selected)) { // Multi-select box $data['multiple'] = 'multiple'; } else { // Single selection (but converted to an array) $selected = array($selected); } $input = ''; return $input; } /** * Creates an HTML form checkbox input tag. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param boolean make the checkbox checked by default * @param string a string to be attached to the end of the attributes * @return string */ public static function checkbox($data, $value = '', $checked = FALSE, $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } $data['type'] = 'checkbox'; if ($checked == TRUE OR (isset($data['checked']) AND $data['checked'] == TRUE)) { $data['checked'] = 'checked'; } else { unset($data['checked']); } return form::input($data, $value, $extra); } /** * Creates an HTML form radio input tag. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param boolean make the radio selected by default * @param string a string to be attached to the end of the attributes * @return string */ public static function radio($data = '', $value = '', $checked = FALSE, $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } $data['type'] = 'radio'; if ($checked == TRUE OR (isset($data['checked']) AND $data['checked'] == TRUE)) { $data['checked'] = 'checked'; } else { unset($data['checked']); } return form::input($data, $value, $extra); } /** * Creates an HTML form submit input tag. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param string a string to be attached to the end of the attributes * @return string */ public static function submit($data = '', $value = '', $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } if (empty($data['name'])) { // Remove the name if it is empty unset($data['name']); } $data['type'] = 'submit'; return form::input($data, $value, $extra); } /** * Creates an HTML form button input tag. * * @param string|array input name or an array of HTML attributes * @param string input value, when using a name * @param string a string to be attached to the end of the attributes * @return string */ public static function button($data = '', $value = '', $extra = '') { if ( ! is_array($data)) { $data = array('name' => $data); } if (empty($data['name'])) { // Remove the name if it is empty unset($data['name']); } if (isset($data['value']) AND empty($value)) { $value = arr::remove('value', $data); } return ''; } /** * Closes an open form tag. * * @param string string to be attached after the closing tag * @return string */ public static function close($extra = '') { return ''."\n".$extra; } /** * Creates an HTML form label tag. * * @param string|array label "for" name or an array of HTML attributes * @param string label text or HTML * @param string a string to be attached to the end of the attributes * @return string */ public static function label($data = '', $text = NULL, $extra = '') { if ( ! is_array($data)) { if (is_string($data)) { // Specify the input this label is for $data = array('for' => $data); } else { // No input specified $data = array(); } } if ($text === NULL AND isset($data['for'])) { // Make the text the human-readable input name $text = ucwords(inflector::humanize($data['for'])); } return ''; } /** * Sorts a key/value array of HTML attributes, putting form attributes first, * and returns an attribute string. * * @param array HTML attributes array * @return string */ public static function attributes($attr, $type = NULL) { if (empty($attr)) return ''; if (isset($attr['name']) AND empty($attr['id']) AND strpos($attr['name'], '[') === FALSE) { if ($type === NULL AND ! empty($attr['type'])) { // Set the type by the attributes $type = $attr['type']; } switch ($type) { case 'text': case 'textarea': case 'password': case 'select': case 'checkbox': case 'file': case 'image': case 'button': case 'submit': // Only specific types of inputs use name to id matching $attr['id'] = $attr['name']; break; } } $order = array ( 'action', 'method', 'type', 'id', 'name', 'value', 'src', 'size', 'maxlength', 'rows', 'cols', 'accept', 'tabindex', 'accesskey', 'align', 'alt', 'title', 'class', 'style', 'selected', 'checked', 'readonly', 'disabled' ); $sorted = array(); foreach ($order as $key) { if (isset($attr[$key])) { // Move the attribute to the sorted array $sorted[$key] = $attr[$key]; // Remove the attribute from unsorted array unset($attr[$key]); } } // Combine the sorted and unsorted attributes and create an HTML string return html::attributes(array_merge($sorted, $attr)); } } // End form