mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
Merge branch '3.1'
This commit is contained in:
commit
18f4f68101
@ -757,6 +757,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
|
|||||||
'LastEdited' => _t('SiteTree.LASTUPDATED', 'Last Updated'),
|
'LastEdited' => _t('SiteTree.LASTUPDATED', 'Last Updated'),
|
||||||
);
|
);
|
||||||
$gridField->getConfig()->getComponentByType('GridFieldSortableHeader')->setFieldSorting(array('getTreeTitle' => 'Title'));
|
$gridField->getConfig()->getComponentByType('GridFieldSortableHeader')->setFieldSorting(array('getTreeTitle' => 'Title'));
|
||||||
|
$gridField->getState()->ParentID = $parentID;
|
||||||
|
|
||||||
if(!$params) {
|
if(!$params) {
|
||||||
$fields = array_merge(array('listChildrenLink' => ''), $fields);
|
$fields = array_merge(array('listChildrenLink' => ''), $fields);
|
||||||
@ -1277,24 +1278,34 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
|
|||||||
$newPage = $page->duplicate();
|
$newPage = $page->duplicate();
|
||||||
|
|
||||||
// ParentID can be hard-set in the URL. This is useful for pages with multiple parents
|
// ParentID can be hard-set in the URL. This is useful for pages with multiple parents
|
||||||
if($_GET['parentID'] && is_numeric($_GET['parentID'])) {
|
if(isset($_GET['parentID']) && is_numeric($_GET['parentID'])) {
|
||||||
$newPage->ParentID = $_GET['parentID'];
|
$newPage->ParentID = $_GET['parentID'];
|
||||||
$newPage->write();
|
$newPage->write();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reload form, data and actions might have changed
|
$this->response->addHeader(
|
||||||
$form = $this->getEditForm($newPage->ID);
|
'X-Status',
|
||||||
|
rawurlencode(_t(
|
||||||
|
'CMSMain.DUPLICATED',
|
||||||
|
"Duplicated '{title}' successfully",
|
||||||
|
array('title' => $newPage->Title)
|
||||||
|
))
|
||||||
|
);
|
||||||
|
$url = Controller::join_links(singleton('CMSPageEditController')->Link('show'), $newPage->ID);
|
||||||
|
$this->response->addHeader('X-ControllerURL', $url);
|
||||||
|
$this->request->addHeader('X-Pjax', 'Content');
|
||||||
|
$this->response->addHeader('X-Pjax', 'Content');
|
||||||
|
|
||||||
return $form->forTemplate();
|
return $this->getResponseNegotiator()->respond($this->request);
|
||||||
} else {
|
} else {
|
||||||
user_error("CMSMain::duplicate() Bad ID: '$id'", E_USER_WARNING);
|
return new SS_HTTPResponse("CMSMain::duplicate() Bad ID: '$id'", 400);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function duplicatewithchildren($request) {
|
public function duplicatewithchildren($request) {
|
||||||
// Protect against CSRF on destructive action
|
// Protect against CSRF on destructive action
|
||||||
if(!SecurityToken::inst()->checkRequest($request)) return $this->httpError(400);
|
if(!SecurityToken::inst()->checkRequest($request)) return $this->httpError(400);
|
||||||
|
increase_time_limit_to();
|
||||||
if(($id = $this->urlParams['ID']) && is_numeric($id)) {
|
if(($id = $this->urlParams['ID']) && is_numeric($id)) {
|
||||||
$page = DataObject::get_by_id("SiteTree", $id);
|
$page = DataObject::get_by_id("SiteTree", $id);
|
||||||
if($page && (!$page->canEdit() || !$page->canCreate())) return Security::permissionFailure($this);
|
if($page && (!$page->canEdit() || !$page->canCreate())) return Security::permissionFailure($this);
|
||||||
@ -1302,34 +1313,23 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
|
|||||||
|
|
||||||
$newPage = $page->duplicateWithChildren();
|
$newPage = $page->duplicateWithChildren();
|
||||||
|
|
||||||
// Reload form, data and actions might have changed
|
$this->response->addHeader(
|
||||||
$form = $this->getEditForm($newPage->ID);
|
'X-Status',
|
||||||
|
rawurlencode(_t(
|
||||||
return $form->forTemplate();
|
'CMSMain.DUPLICATEDWITHCHILDREN',
|
||||||
} else {
|
"Duplicated '{title}' and children successfully",
|
||||||
user_error("CMSMain::duplicate() Bad ID: '$id'", E_USER_WARNING);
|
array('title' => $newPage->Title)
|
||||||
}
|
))
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return the version number of this application.
|
|
||||||
* Uses the subversion path information in <mymodule>/silverstripe_version
|
|
||||||
* (automacially replaced by build scripts).
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public function CMSVersion() {
|
|
||||||
$cmsVersion = file_get_contents(CMS_PATH . '/silverstripe_version');
|
|
||||||
if(!$cmsVersion) $cmsVersion = _t('LeftAndMain.VersionUnknown', 'Unknown');
|
|
||||||
|
|
||||||
$frameworkVersion = file_get_contents(FRAMEWORK_PATH . '/silverstripe_version');
|
|
||||||
if(!$frameworkVersion) $frameworkVersion = _t('LeftAndMain.VersionUnknown', 'Unknown');
|
|
||||||
|
|
||||||
return sprintf(
|
|
||||||
"CMS: %s Framework: %s",
|
|
||||||
$cmsVersion,
|
|
||||||
$frameworkVersion
|
|
||||||
);
|
);
|
||||||
|
$url = Controller::join_links(singleton('CMSPageEditController')->Link('show'), $newPage->ID);
|
||||||
|
$this->response->addHeader('X-ControllerURL', $url);
|
||||||
|
$this->request->addHeader('X-Pjax', 'Content');
|
||||||
|
$this->response->addHeader('X-Pjax', 'Content');
|
||||||
|
|
||||||
|
return $this->getResponseNegotiator()->respond($this->request);
|
||||||
|
} else {
|
||||||
|
return new SS_HTTPResponse("CMSMain::duplicatewithchildren() Bad ID: '$id'", 400);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function providePermissions() {
|
public function providePermissions() {
|
||||||
|
@ -117,12 +117,10 @@ class RootURLController extends Controller {
|
|||||||
return $this->response;
|
return $this->response;
|
||||||
}
|
}
|
||||||
|
|
||||||
$request = new SS_HTTPRequest (
|
$request->setUrl(self::get_homepage_link() . '/');
|
||||||
$request->httpMethod(), self::get_homepage_link() . '/', $request->getVars(), $request->postVars()
|
|
||||||
);
|
|
||||||
$request->match('$URLSegment//$Action', true);
|
$request->match('$URLSegment//$Action', true);
|
||||||
|
|
||||||
$controller = new ModelAsController();
|
$controller = new ModelAsController();
|
||||||
|
|
||||||
$result = $controller->handleRequest($request, $model);
|
$result = $controller->handleRequest($request, $model);
|
||||||
|
|
||||||
$this->popCurrent();
|
$this->popCurrent();
|
||||||
|
@ -70,7 +70,8 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
$(".cms-add-form #PageType li").entwine({
|
$(".cms-add-form #PageType li").entwine({
|
||||||
onclick: function() {
|
onclick: function(e) {
|
||||||
|
e.preventDefault();
|
||||||
this.setSelected(true);
|
this.setSelected(true);
|
||||||
},
|
},
|
||||||
setSelected: function(bool) {
|
setSelected: function(bool) {
|
||||||
@ -90,9 +91,18 @@
|
|||||||
|
|
||||||
$(".cms-page-add-button").entwine({
|
$(".cms-page-add-button").entwine({
|
||||||
onclick: function(e) {
|
onclick: function(e) {
|
||||||
var selected = $('.cms-tree').jstree('get_selected'),
|
var tree = $('.cms-tree'), list = $('.cms-list'), parentId = 0;
|
||||||
parentId = selected ? $(selected[0]).data('id') : null,
|
|
||||||
data = {selector: this.data('targetPanel'),pjax: this.data('pjax')},
|
// Choose parent ID either from tree or list view, depending which is visible
|
||||||
|
if(tree.is(':visible')) {
|
||||||
|
var selected = tree.jstree('get_selected');
|
||||||
|
parentId = selected ? $(selected[0]).data('id') : null;
|
||||||
|
} else {
|
||||||
|
var state = list.find('input[name="Page[GridState]"]').val();
|
||||||
|
if(state) parentId = parseInt(JSON.parse(state).ParentID, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
var data = {selector: this.data('targetPanel'),pjax: this.data('pjax')},
|
||||||
url = parentId ? ss.i18n.sprintf(this.data('urlAddpage'), parentId) : this.attr('href');
|
url = parentId ? ss.i18n.sprintf(this.data('urlAddpage'), parentId) : this.attr('href');
|
||||||
|
|
||||||
$('.cms-container').loadPanel(url, null, data);
|
$('.cms-container').loadPanel(url, null, data);
|
||||||
|
@ -59,6 +59,27 @@
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
menuitems['duplicate'] = {
|
||||||
|
'label': ss.i18n._t('Tree.Duplicate'),
|
||||||
|
'submenu': [
|
||||||
|
{
|
||||||
|
'label': ss.i18n._t('Tree.ThisPageOnly'),
|
||||||
|
'action': function(obj) {
|
||||||
|
$('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf(
|
||||||
|
self.data('urlDuplicate'), obj.data('id')
|
||||||
|
));
|
||||||
|
}
|
||||||
|
},{
|
||||||
|
'label': ss.i18n._t('Tree.ThisPageAndSubpages'),
|
||||||
|
'action': function(obj) {
|
||||||
|
$('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf(
|
||||||
|
self.data('urlDuplicatewithchildren'), obj.data('id')
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
return menuitems;
|
return menuitems;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -29,7 +29,10 @@ if(typeof(ss) == 'undefined' || typeof(ss.i18n) == 'undefined') {
|
|||||||
'AssetAdmin.ConfirmDelete': 'Do you really want to delete this folder and all contained files?',
|
'AssetAdmin.ConfirmDelete': 'Do you really want to delete this folder and all contained files?',
|
||||||
'Folder.Name': 'Folder name',
|
'Folder.Name': 'Folder name',
|
||||||
'Tree.AddSubPage': 'Add new page here',
|
'Tree.AddSubPage': 'Add new page here',
|
||||||
|
'Tree.Duplicate': 'Duplicate',
|
||||||
'Tree.EditPage': 'Edit',
|
'Tree.EditPage': 'Edit',
|
||||||
|
'Tree.ThisPageOnly': 'This page only',
|
||||||
|
'Tree.ThisPageAndSubpages': 'This page and subpages',
|
||||||
'CMSMain.ConfirmRestoreFromLive': "Do you really want to copy the published content to the draft site?",
|
'CMSMain.ConfirmRestoreFromLive': "Do you really want to copy the published content to the draft site?",
|
||||||
'CMSMain.RollbackToVersion': "Do you really want to roll back to version #%s of this page?",
|
'CMSMain.RollbackToVersion': "Do you really want to roll back to version #%s of this page?",
|
||||||
'URLSEGMENT.Edit': 'Edit',
|
'URLSEGMENT.Edit': 'Edit',
|
||||||
|
@ -80,6 +80,8 @@ en:
|
|||||||
DELETE: 'Delete draft'
|
DELETE: 'Delete draft'
|
||||||
DELETEFP: Delete
|
DELETEFP: Delete
|
||||||
DESCREMOVED: 'and {count} descendants'
|
DESCREMOVED: 'and {count} descendants'
|
||||||
|
DUPLICATED: 'Duplicated ''{title}'' successfully'
|
||||||
|
DUPLICATEDWITHCHILDREN: 'Duplicated ''{title}'' and children successfully'
|
||||||
EMAIL: Email
|
EMAIL: Email
|
||||||
EditTree: 'Edit Tree'
|
EditTree: 'Edit Tree'
|
||||||
ListFiltered: 'Filtered list.'
|
ListFiltered: 'Filtered list.'
|
||||||
|
@ -82,6 +82,8 @@ en_GB:
|
|||||||
DELETE: 'Delete from the draft site'
|
DELETE: 'Delete from the draft site'
|
||||||
DELETEFP: 'Delete from the published site'
|
DELETEFP: 'Delete from the published site'
|
||||||
DESCREMOVED: 'and {count} descendants'
|
DESCREMOVED: 'and {count} descendants'
|
||||||
|
DUPLICATED: 'Duplicated ''{title}'' successfully'
|
||||||
|
DUPLICATEDWITHCHILDREN: 'Duplicated ''{title}'' and children successfully'
|
||||||
EMAIL: Email
|
EMAIL: Email
|
||||||
EditTree: 'Edit Tree'
|
EditTree: 'Edit Tree'
|
||||||
ListFiltered: 'Filtered list.'
|
ListFiltered: 'Filtered list.'
|
||||||
|
@ -19,7 +19,7 @@ $ExtraTreeTools
|
|||||||
</div>
|
</div>
|
||||||
<% end_if %>
|
<% end_if %>
|
||||||
|
|
||||||
<div class="cms-tree" data-url-tree="$Link(getsubtree)" data-url-savetreenode="$Link(savetreenode)" data-url-updatetreenodes="$Link(updatetreenodes)" data-url-addpage="{$LinkPageAdd('AddForm/?action_doAdd=1')}&ParentID=%s&PageType=%s&SecurityID=$SecurityID" data-url-editpage="$LinkPageEdit('%s')" data-hints="$SiteTreeHints.XML">
|
<div class="cms-tree" data-url-tree="$Link(getsubtree)" data-url-savetreenode="$Link(savetreenode)" data-url-updatetreenodes="$Link(updatetreenodes)" data-url-addpage="{$LinkPageAdd('AddForm/?action_doAdd=1')}&ParentID=%s&PageType=%s&SecurityID=$SecurityID" data-url-editpage="$LinkPageEdit('%s')" data-url-duplicate="{$Link('duplicate/%s')}?SecurityID=$SecurityID" data-url-duplicatewithchildren="{$Link('duplicatewithchildren/%s')}?SecurityID=$SecurityID" data-hints="$SiteTreeHints.XML">
|
||||||
$SiteTreeAsUL
|
$SiteTreeAsUL
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
Reference in New Issue
Block a user