mirror of
https://github.com/silverstripe/silverstripe-subsites
synced 2024-10-22 11:05:55 +02:00
MERGE subsite treedropdown fix from trunk (from r86329)
This commit is contained in:
parent
9e63443b97
commit
f7dba96157
@ -37,6 +37,11 @@ class RelatedPageLink extends DataObject {
|
|||||||
"ID",
|
"ID",
|
||||||
"MenuTitle"
|
"MenuTitle"
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if(Controller::curr()->getRequest()) {
|
||||||
|
$subsiteID = Controller::curr()->getRequest()->getVar('TreeDropdownField_ComplexTableField_Popup_AddForm_RelatedPageID_SubsiteID');
|
||||||
|
$pageSelectionField->setSubsiteID($subsiteID);
|
||||||
|
}
|
||||||
|
|
||||||
$pageSelectionField->setFilterFunction(create_function('$item', 'return $item->ClassName != "VirtualPage";'));
|
$pageSelectionField->setFilterFunction(create_function('$item', 'return $item->ClassName != "VirtualPage";'));
|
||||||
|
|
||||||
|
@ -1,15 +1,26 @@
|
|||||||
SubsitesTreeDropdownField = Class.extend('TreeDropdownField');
|
SubsitesTreeDropdownField = Class.extend('TreeDropdownField');
|
||||||
SubsitesTreeDropdownField.prototype = {
|
SubsitesTreeDropdownField.prototype = {
|
||||||
|
|
||||||
//subsiteID: null,
|
subsiteID: function() {
|
||||||
|
var subsiteSel = $$('#CopyContentFromID_SubsiteID select')[0];
|
||||||
|
subsiteSel.onchange = (function() {
|
||||||
|
this.createTreeNode(true);
|
||||||
|
this.ajaxGetTree((function(response) {
|
||||||
|
this.newTreeReady(response, true);
|
||||||
|
this.updateTreeLabel();
|
||||||
|
}).bind(this));
|
||||||
|
}).bind(this);
|
||||||
|
return subsiteSel.options[subsiteSel.selectedIndex].value;
|
||||||
|
},
|
||||||
|
|
||||||
ajaxGetTree: function(after) {
|
ajaxGetTree: function(after) {
|
||||||
|
// This if block is necessary to maintain both 2.2 and 2.3 support
|
||||||
var baseURL = this.helperURLBase();
|
var baseURL = this.helperURLBase();
|
||||||
// Can't force value because it might be on a different subsite!
|
if(baseURL.match('action_callfieldmethod')) var ajaxURL = baseURL+ '&methodName=gettree&forceValues=' + this.inputTag.value;
|
||||||
var ajaxURL = baseURL+ 'gettree?forceValues=' + 0; //this.inputTag.value;
|
else var ajaxURL = baseURL+ 'gettree?forceValues=' + this.inputTag.value;
|
||||||
|
|
||||||
// Customised: Append subsiteid (evaluated in SubsitesVirtualPage.php)
|
// Customized: Append subsiteid (evaluated in SubsitesVirtualPage.php)
|
||||||
ajaxURL += '&' + this.id + '_SubsiteID=' + parseInt(this.subsiteID);
|
ajaxURL += '&' + this.id + '_SubsiteID=' + parseInt(this.subsiteID());
|
||||||
|
|
||||||
ajaxURL += $('SecurityID') ? '&SecurityID=' + $('SecurityID').value : '';
|
ajaxURL += $('SecurityID') ? '&SecurityID=' + $('SecurityID').value : '';
|
||||||
new Ajax.Request(ajaxURL, {
|
new Ajax.Request(ajaxURL, {
|
||||||
@ -25,8 +36,11 @@ SubsitesTreeDropdownField.prototype = {
|
|||||||
var ul = this.treeNodeHolder();
|
var ul = this.treeNodeHolder();
|
||||||
ul.innerHTML = ss.i18n._t('LOADING');
|
ul.innerHTML = ss.i18n._t('LOADING');
|
||||||
|
|
||||||
|
// This if block is necessary to maintain both 2.2 and 2.3 support
|
||||||
var baseURL = this.options.dropdownField.helperURLBase();
|
var baseURL = this.options.dropdownField.helperURLBase();
|
||||||
var ajaxURL = baseURL+ 'getsubtree?SubtreeRootID=' + this.getIdx();
|
|
||||||
|
if(baseURL.match('action_callfieldmethod')) var ajaxURL = baseURL+ '&methodName=getsubtree&SubtreeRootID=' + this.getIdx();
|
||||||
|
else var ajaxURL = baseURL+ 'getsubtree?SubtreeRootID=' + this.getIdx();
|
||||||
|
|
||||||
// Find the root of the tree - this points to a list item in the tree, not the root div we actually want
|
// Find the root of the tree - this points to a list item in the tree, not the root div we actually want
|
||||||
// @todo: We should be using framework API calls to find the tree
|
// @todo: We should be using framework API calls to find the tree
|
||||||
@ -34,7 +48,7 @@ SubsitesTreeDropdownField.prototype = {
|
|||||||
while (tree && !tree.className.match(/(^| )SubsitesTreeDropdownField( |$)/)) tree = tree.parentNode;
|
while (tree && !tree.className.match(/(^| )SubsitesTreeDropdownField( |$)/)) tree = tree.parentNode;
|
||||||
|
|
||||||
// Customized: Append subsiteid (evaluated in SubsitesVirtualPage.php)
|
// Customized: Append subsiteid (evaluated in SubsitesVirtualPage.php)
|
||||||
ajaxURL += '&' + tree.id + '_SubsiteID=' + parseInt(tree.subsiteID);
|
ajaxURL += '&' + this.id + '_SubsiteID=' + parseInt(this.subsiteID());
|
||||||
ajaxURL += $('SecurityID') ? '&SecurityID=' + $('SecurityID').value : '';
|
ajaxURL += $('SecurityID') ? '&SecurityID=' + $('SecurityID').value : '';
|
||||||
|
|
||||||
new Ajax.Request(ajaxURL, {
|
new Ajax.Request(ajaxURL, {
|
||||||
@ -43,4 +57,4 @@ SubsitesTreeDropdownField.prototype = {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
SubsitesTreeDropdownField.applyTo('div.SubsitesTreeDropdownField');
|
SubsitesTreeDropdownField.applyTo('div.SubsitesTreeDropdownField');
|
Loading…
Reference in New Issue
Block a user