BUGFIX Added support for $fields parameter in CMSMain->getEditForm(), don't require 'ClassName' field in save() as its not included in getCMSFields() any longer.

This commit is contained in:
Ingo Schommer 2011-04-16 17:53:47 +12:00
parent bb4dbaa02c
commit 8af9c546cf

View File

@ -398,9 +398,11 @@ JS;
} }
/** /**
* Calls {@link SiteTree->getCMSFields()} * @param Int $id
* @param FieldSet $fields
* @return Form
*/ */
public function getEditForm($id = null) { public function getEditForm($id = null, $fields = null) {
// Include JavaScript to ensure HtmlEditorField works. // Include JavaScript to ensure HtmlEditorField works.
HtmlEditorField::include_js(); HtmlEditorField::include_js();
@ -411,7 +413,7 @@ JS;
$record = $this->getRecord($id); $record = $this->getRecord($id);
if($record && !$record->canView()) return Security::permissionFailure($this); if($record && !$record->canView()) return Security::permissionFailure($this);
$fields = $form->Fields(); if(!$fields) $fields = $form->Fields();
$actions = $form->Actions(); $actions = $form->Actions();
if($record) { if($record) {
@ -533,7 +535,7 @@ JS;
$record->writeWithoutVersion(); $record->writeWithoutVersion();
// Update the class instance if necessary // Update the class instance if necessary
if($data['ClassName'] != $record->ClassName) { if(isset($data['ClassName']) && $data['ClassName'] != $record->ClassName) {
$newClassName = $record->ClassName; $newClassName = $record->ClassName;
// The records originally saved attribute was overwritten by $form->saveInto($record) before. // The records originally saved attribute was overwritten by $form->saveInto($record) before.
// This is necessary for newClassInstance() to work as expected, and trigger change detection // This is necessary for newClassInstance() to work as expected, and trigger change detection
@ -544,7 +546,7 @@ JS;
} }
// save form data into record // save form data into record
$form->saveInto($record, true); $form->saveInto($record);
$record->write(); $record->write();
// If the 'Save & Publish' button was clicked, also publish the page // If the 'Save & Publish' button was clicked, also publish the page
@ -552,8 +554,10 @@ JS;
$record->doPublish(); $record->doPublish();
// Update classname with original and get new instance (see above for explanation) // Update classname with original and get new instance (see above for explanation)
$record->setClassName($data['ClassName']); if(isset($data['ClassName'])) {
$publishedRecord = $record->newClassInstance($record->ClassName); $record->setClassName($data['ClassName']);
$publishedRecord = $record->newClassInstance($record->ClassName);
}
$this->response->addHeader( $this->response->addHeader(
'X-Status', 'X-Status',
@ -564,12 +568,12 @@ JS;
PR_MEDIUM, PR_MEDIUM,
'Status message after publishing a page, showing the page title' 'Status message after publishing a page, showing the page title'
), ),
$publishedRecord->Title $record->Title
) )
); );
// Reload form, data and actions might have changed // Reload form, data and actions might have changed
$form = $this->getEditForm($publishedRecord->ID); $form = $this->getEditForm($record->ID);
} else { } else {
$this->response->addHeader('X-Status', _t('LeftAndMain.SAVEDUP')); $this->response->addHeader('X-Status', _t('LeftAndMain.SAVEDUP'));