X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=functions%2Fforms.php;h=23215bb6ada42e26b5330c32abd07b4c3215b439;hp=0be61fb58fd94299d4c3b7877134e3d806244448;hb=5ce1ef683e48c352cc9c25c21542371a99d5401a;hpb=38d93650379d3166a2e9b1c7fbfea3eaa21ad665 diff --git a/functions/forms.php b/functions/forms.php index 0be61fb5..23215bb6 100644 --- a/functions/forms.php +++ b/functions/forms.php @@ -25,7 +25,7 @@ * @link http://www.section508.gov/ Section 508 * @link http://www.w3.org/WAI/ Web Accessibility Initiative (WAI) * @link http://www.w3.org/TR/html4/ W3.org HTML 4.01 form specs - * @copyright © 2004-2007 The SquirrelMail Project Team + * @copyright © 2004-2009 The SquirrelMail Project Team * @license http://opensource.org/licenses/gpl-license.php GNU Public License * @version $Id$ * @package squirrelmail @@ -76,12 +76,17 @@ function addInputField($sType, $aAttribs=array()) { * Password input field * @param string $sName field name * @param string $sValue initial password value - * @param array $aAttribs (since 1.5.1) extra attributes - * @return string html formated password field + * @param integer $iSize field size (number of characters) + * @param integer $iMaxlength maximum number of characters the user may enter + * @param array $aAttribs (since 1.5.1) extra attributes - should be given + * in the form array('attribute_name' => 'attribute_value', ...) + * @return string html formated password field */ -function addPwField($sName, $sValue = null, $aAttribs=array()) { +function addPwField($sName, $sValue = '', $iSize = 0, $iMaxlength = 0, $aAttribs=array()) { $aAttribs['name'] = $sName; - $aAttribs['value'] = (! is_null($sValue) ? $sValue : ''); + $aAttribs['value'] = $sValue; + if ($iSize) $aAttribs['size'] = (int)$iSize; + if ($iMaxlength) $aAttribs['maxlength'] = (int)$iMaxlength; // add default css if (! isset($aAttribs['class'])) $aAttribs['class'] = 'sqmpwfield'; return addInputField('password',$aAttribs); @@ -331,3 +336,39 @@ function addForm($sAction, $sMethod = 'post', $sName = '', $sEnctype = '', $sCha return $oTemplate->fetch('form.tpl'); } +/** + * Creates unique widget names + * + * Names are formatted as such: "send1", "send2", "send3", etc., + * where "send" in this example is what was given for $base_name + * + * @param string $base_name The name upon which to base the + * returned widget name. + * @param boolean $return_count When TRUE, this function will + * return the last number used to + * create a widget name for $base_name + * (OPTIONAL; default = FALSE). + * + * @return mixed When $return_output is FALSE, a string containing + * the unique widget name; otherwise an integer with + * the last number used to create the last widget + * name for the given $base_name (where 0 (zero) means + * that no such widgets have been created yet). + * + * @since 1.5.2 + * + */ +function unique_widget_name($base_name, $return_count=FALSE) +{ + static $counts = array(); + + if (!isset($counts[$base_name])) + $counts[$base_name] = 0; + + if ($return_count) + return $counts[$base_name]; + + ++$counts[$base_name]; + return $base_name . $counts[$base_name]; +} +