From 295cd5077e707ca0b7cd47738c833667fcbacb1a Mon Sep 17 00:00:00 2001 From: Sean Harvey Date: Thu, 19 Jun 2008 10:29:47 +0000 Subject: [PATCH] API CHANGE Ticket #2562 - Cleaner instanciation of MultiForm subclass, init() is removed with the move of session/step initialization to __construct() --- code/MultiForm.php | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/code/MultiForm.php b/code/MultiForm.php index 583c159..58a747b 100644 --- a/code/MultiForm.php +++ b/code/MultiForm.php @@ -74,15 +74,21 @@ abstract class MultiForm extends Form { ); /** - * Perform actions when the multiform is first started. - * - * It does NOT work like a normal controller init()! It has to be explicity called when MultiForm - * is intanciated on your controller. @TODO perhaps find a better name, that doesn't quite conflict. - * - * This method sets up the session, figures out the current step, sets the current step, then - * takes the fields, actions and validation (if any) for the step, setting up the form. + * We start the MultiForm here. Before we start the MultiForm process, + * like setting up the session, we must pass in empty FieldSet objects + * to the Form->__construct(), as it requires them to be present. + * + * @param ContentController instance $controller Controller this form is created on + * @param string $name The form name, typically the same as the method name */ - public function init() { + public function __construct($controller, $name) { + + // We don't have any fields directly on here, they're on the step classes + $fields = new FieldSet(); + $actions = new FieldSet(); + + parent::__construct($controller, $name, $fields, $actions); + // Set up the session for this MultiForm instance $this->setSession();