aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--views/default/input/checkbox.php20
-rw-r--r--views/default/input/checkboxes.php27
2 files changed, 35 insertions, 12 deletions
diff --git a/views/default/input/checkbox.php b/views/default/input/checkbox.php
index 32bc323fd..e70064ddb 100644
--- a/views/default/input/checkbox.php
+++ b/views/default/input/checkbox.php
@@ -1,10 +1,17 @@
<?php
/**
* Elgg checkbox input
- * Displays a checkbox input field
+ * Displays a checkbox input tag
*
* @package Elgg
* @subpackage Core
+ *
+ *
+ * Pass input tag attributes as key value pairs. For a list of allowable
+ * attributes, see http://www.w3schools.com/tags/tag_input.asp
+ *
+ * @uses mixed $vars['default'] The default value to submit if not checked.
+ * Optional, defaults to 0. Set to false for no default.
*/
$defaults = array(
@@ -13,6 +20,17 @@ $defaults = array(
$vars = array_merge($defaults, $vars);
+if (isset($vars['default'])) {
+ $default = $vars['default'];
+ unset($vars['default']);
+} else {
+ $default = 0;
+}
+
+if (isset($vars['name']) && $default !== false) {
+ echo "<input type=\"hidden\" name=\"{$vars['name']}\" value=\"$default\"/>";
+}
+
?>
<input type="checkbox" <?php echo elgg_format_attributes($vars); ?> /> \ No newline at end of file
diff --git a/views/default/input/checkboxes.php b/views/default/input/checkboxes.php
index 46254633b..94f01867c 100644
--- a/views/default/input/checkboxes.php
+++ b/views/default/input/checkboxes.php
@@ -5,19 +5,23 @@
* NB: This also includes a hidden input with the same name as the checkboxes
* to make sure something is sent to the server. The default value is 0.
* If using JS, be specific to avoid selecting the hidden default value:
- * $('input[type=checkbox][name=internalname])
+ * $('input[type=checkbox][name=internalname]')
*
* @package Elgg
* @subpackage Core
*
- * @uses string $vars['internalname'] The name of the input fields (Forced to an array by appending [])
- * @uses array $vars['options'] An array of strings representing the label => option for the each checkbox field
- * @uses string $vars['internalid'] The id for each input field. Optional (Only use this with a single value.)
- * @uses string $vars['default'] The default value to send if nothing is checked. Optional, defaults to 0.
- * @uses bool $vars['disabled'] Make all input elements disabled. Optional.
- * @uses string $vars['value'] The current value. Optional.
- * @uses string $vars['class'] The class of each input element. Optional.
- * @uses string $vars['js'] Any Javascript to enter into the input tag. Optional.
+ * @uses string $vars['internalname'] The name of the input fields
+ * (Forced to an array by appending [])
+ * @uses array $vars['options'] An array of strings representing the
+ * label => option for the each checkbox field
+ * @uses string $vars['internalid'] The id for each input field. Optional
+ * (Only use this with a single value.)
+ * @uses string $vars['default'] The default value to send if nothing is checked.
+ * Optional, defaults to 0. Set to FALSE for no default.
+ * @uses bool $vars['disabled'] Make all input elements disabled. Optional.
+ * @uses string $vars['value'] The current value. Optional.
+ * @uses string $vars['class'] The class of each input element. Optional.
+ * @uses string $vars['js'] Any Javascript to enter into the input tag. Optional.
*
*/
@@ -38,11 +42,11 @@ $js = (isset($vars['js'])) ? $vars['js'] : '';
if ($options) {
// include a default value so if nothing is checked 0 will be passed.
- if ($internalname) {
+ if ($internalname && $default !== FALSE) {
echo "<input type=\"hidden\" name=\"$internalname\" value=\"$default\">";
}
- foreach($options as $label => $option) {
+ foreach ($options as $label => $option) {
// @hack - This sorta checks if options is not an assoc array and then
// ignores the label (because it's just the index) and sets the value ($option)
// as the label.
@@ -58,6 +62,7 @@ if ($options) {
'disabled' => $disabled,
'id' => $id,
'js' => $js,
+ 'default' => false,
);
if ($class) {