mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 06:05:56 +00:00
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:
parent
4ee4878dc1
commit
0ba1e35ece
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user