From 10d5f41f249ceeb8cb0d2f3e92e4ad5b56f6b7ad Mon Sep 17 00:00:00 2001 From: Will Rossiter Date: Fri, 8 May 2009 04:27:49 +0000 Subject: [PATCH] BUGFIX: fixed rules with date fields and header fields. Appilied components of #4006 --- code/UserDefinedForm.php | 22 ++++++++++++++++------ code/editor/EditableFormHeading.php | 2 +- 2 files changed, 17 insertions(+), 7 deletions(-) diff --git a/code/UserDefinedForm.php b/code/UserDefinedForm.php index 31d4eef..bda1962 100755 --- a/code/UserDefinedForm.php +++ b/code/UserDefinedForm.php @@ -221,10 +221,15 @@ class UserDefinedForm_Controller extends Page_Controller { if($fieldValidationOptions) { $fieldValidationRules[$field->Name] = $fieldValidationOptions; } + $fieldId = $field->Name; + + if($field->ClassName == 'EditableFormHeading') { + $fieldId = 'Form_Form_'.$field->Name; + } // Is this Field Show by Default if(!$field->ShowOnLoad()) { - $defaults .= "$(\"#" . $field->Name . "\").hide();\n"; + $defaults .= "$(\"#" . $fieldId . "\").hide();\n"; } // Check for field dependencies / default @@ -254,8 +259,13 @@ class UserDefinedForm_Controller extends Page_Controller { $view = (isset($dependency['Display']) && $dependency['Display'] == "Hide") ? "hide" : "show"; $opposite = ($view == "show") ? "hide" : "show"; - // what action do we need to keep track of - $Action = ($formFieldWatch->ClassName == "EditableTextField") ? "keyup" : "change"; + // what action do we need to keep track of. Something nicer here maybe? + // @todo encapulsation + $action = "change"; + + if($formFieldWatch->ClassName == "EditableTextField" || $formFieldWatch->ClassName == "EditableDateField") { + $action = "keyup"; + } // is this field a special option field $checkboxField = false; @@ -283,12 +293,12 @@ class UserDefinedForm_Controller extends Page_Controller { break; } // put it all together - $CustomDisplayRules .= $fieldToWatch.".$Action(function() { + $CustomDisplayRules .= $fieldToWatch.".$action(function() { if(". $expression ." ) { - $(\"#". $field->Name ."\").".$view."(); + $(\"#". $fieldId ."\").".$view."(); } else { - $(\"#". $field->Name ."\").".$opposite."(); + $(\"#". $fieldId ."\").".$opposite."(); } });"; } diff --git a/code/editor/EditableFormHeading.php b/code/editor/EditableFormHeading.php index 27e5844..008c1a5 100755 --- a/code/editor/EditableFormHeading.php +++ b/code/editor/EditableFormHeading.php @@ -24,7 +24,7 @@ class EditableFormHeading extends EditableFormField { } function getFormField() { - $labelField = new HeaderField('FormHeadingLabel',$this->Title, $this->getSetting('Level')); + $labelField = new HeaderField($this->Name,$this->Title, $this->getSetting('Level')); $labelField->addExtraClass('FormHeading'); return $labelField;