BUGFIX: make the javascript-producing functions behave in the same way. Now they will return a javascript snippet and the caller is responsible for adding it to a FormResponse. Removes the duplication in AJAX response which happened when FormResponse::add has been used before the call to JS helper functions (#5359)

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/branches/2.4@103083 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Mateusz Uzdowski 2010-04-19 21:17:47 +00:00 committed by Sam Minnee
parent 4ee4878dc1
commit 0ba1e35ece

View File

@ -618,7 +618,6 @@ JS;
*/ */
public function save($urlParams, $form) { public function save($urlParams, $form) {
$className = $this->stat('tree_class'); $className = $this->stat('tree_class');
$result = '';
$SQL_id = Convert::raw2sql($_REQUEST['ID']); $SQL_id = Convert::raw2sql($_REQUEST['ID']);
if(substr($SQL_id,0,3) != 'new') { if(substr($SQL_id,0,3) != 'new') {
@ -690,12 +689,12 @@ JS;
if($added = DataObjectLog::getAdded('SiteTree')) { if($added = DataObjectLog::getAdded('SiteTree')) {
foreach($added as $page) { foreach($added as $page) {
if($page->ID != $record->ID) $result .= $this->addTreeNodeJS($page); if($page->ID != $record->ID) FormResponse::add($this->addTreeNodeJS($page));
} }
} }
if($deleted = DataObjectLog::getDeleted('SiteTree')) { if($deleted = DataObjectLog::getDeleted('SiteTree')) {
foreach($deleted as $page) { foreach($deleted as $page) {
if($page->ID != $record->ID) $result .= $this->deleteTreeNodeJS($page); if($page->ID != $record->ID) FormResponse::add($this->deleteTreeNodeJS($page));
} }
} }
if($changed = DataObjectLog::getChanged('SiteTree')) { if($changed = DataObjectLog::getChanged('SiteTree')) {
@ -789,7 +788,7 @@ JS;
// BUGFIX: Changed icon only shows after Save button is clicked twice http://support.silverstripe.com/gsoc/ticket/76 // BUGFIX: Changed icon only shows after Save button is clicked twice http://support.silverstripe.com/gsoc/ticket/76
$title = Convert::raw2js($record->TreeTitle()); $title = Convert::raw2js($record->TreeTitle());
FormResponse::add("$('sitetree').setNodeTitle(\"$record->ID\", \"$title\");"); FormResponse::add("$('sitetree').setNodeTitle(\"$record->ID\", \"$title\");");
$result .= $this->getActionUpdateJS($record); FormResponse::add($this->getActionUpdateJS($record));
FormResponse::status_message($message, "good"); FormResponse::status_message($message, "good");
FormResponse::update_status($record->Status); FormResponse::update_status($record->Status);
@ -801,7 +800,9 @@ JS;
} }
/** /**
* Return a piece of javascript that will update the actions of the main form * Returns a javascript snippet that will update the actions of the main form
*
* @return string
*/ */
public function getActionUpdateJS($record) { public function getActionUpdateJS($record) {
// Get the new action buttons // Get the new action buttons
@ -812,13 +813,13 @@ JS;
$actionList .= $action->Field() . ' '; $actionList .= $action->Field() . ' ';
} }
FormResponse::add("$('Form_EditForm').loadActionsFromString('" . Convert::raw2js($actionList) . "');"); return "$('Form_EditForm').loadActionsFromString('" . Convert::raw2js($actionList) . "');";
return FormResponse::respond();
} }
/** /**
* Return JavaScript code to generate a tree node for the given page, if visible * Returns a javascript snippet to generate a tree node for the given page, if visible
*
* @return string
*/ */
public function addTreeNodeJS($page, $select = false) { public function addTreeNodeJS($page, $select = false) {
$parentID = (int)$page->ParentID; $parentID = (int)$page->ParentID;
@ -829,11 +830,12 @@ var parentNode = $('sitetree').getTreeNodeByIdx($parentID);
if(parentNode) parentNode.appendTreeNode(newNode); if(parentNode) parentNode.appendTreeNode(newNode);
JS; JS;
$response .= ($select ? "newNode.selectTreeNode();\n" : "") ; $response .= ($select ? "newNode.selectTreeNode();\n" : "") ;
FormResponse::add($response); return $response;
return FormResponse::respond();
} }
/** /**
* Return JavaScript code to remove a tree node for the given page, if it exists. * Returns a javascript snippet to remove a tree node for the given page, if it exists.
*
* @return string
*/ */
public function deleteTreeNodeJS($page) { public function deleteTreeNodeJS($page) {
$id = $page->ID ? $page->ID : $page->OldID; $id = $page->ID ? $page->ID : $page->OldID;
@ -842,14 +844,13 @@ var node = $('sitetree').getTreeNodeByIdx($id);
if(node && node.parentTreeNode) node.parentTreeNode.removeTreeNode(node); if(node && node.parentTreeNode) node.parentTreeNode.removeTreeNode(node);
$('Form_EditForm').closeIfSetTo($id); $('Form_EditForm').closeIfSetTo($id);
JS; JS;
FormResponse::add($response);
// If we have that page selected currently, then clear that info from the session // If we have that page selected currently, then clear that info from the session
if(Session::get("{$this->class}.currentPage") == $id) { if(Session::get("{$this->class}.currentPage") == $id) {
$this->setCurrentPageID(null); $this->setCurrentPageID(null);
} }
return FormResponse::respond(); return $response;
} }
/** /**