From b6dbeec30d45cbc7cfc0302eaa410030fbc9b725 Mon Sep 17 00:00:00 2001 From: Mark Rickerby Date: Thu, 13 Mar 2008 01:39:57 +0000 Subject: [PATCH] initial tweaks to Form to better support use in template control blocks git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@50988 467b73ca-7a2a-4603-9d3b-597d59a354a9 --- forms/Form.php | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/forms/Form.php b/forms/Form.php index 101111b87..1fca22c7f 100644 --- a/forms/Form.php +++ b/forms/Form.php @@ -184,11 +184,12 @@ class Form extends ViewableData { $this->validator->removeValidation(); } + /** - * Return the form's fields - used by the templates - * @return FieldSet The form fields + * Generate extra special fields - namely the SecurityID field + * @todo Is there anything wrong with putting this in __construct? */ - function Fields() { + protected function genExtraFields() { if(!$this->securityTokenAdded && $this->securityTokenEnabled()) { if(Session::get('SecurityID')) { $securityID = Session::get('SecurityID'); @@ -200,10 +201,29 @@ class Form extends ViewableData { $this->fields->push(new HiddenField('SecurityID', '', $securityID)); $this->securityTokenAdded = true; } - + } + + /** + * Return the form's fields - used by the templates + * @return FieldSet The form fields + */ + function Fields() { + $this->genExtraFields(); return $this->fields; } + /** + * Return a block of HTML containing all the hidden fields for this form. + * Useful when doing custom field layouts + */ + function HiddenFields() { + $output = ""; + foreach($this->fields->dataFields() as $field) { + if($field instanceof HiddenField) $output .= $field->Field(); + } + return $output; + } + /** * Setter for the form fields. * @@ -220,6 +240,7 @@ class Form extends ViewableData { * @return FormField */ function dataFieldByName($name) { + $this->genExtraFields(); return $this->fields->dataFieldByName($name); }